前些天我发了一篇关于AR的配置的文章,是我帮一位刚学习AR的朋友做了一个小实例后写上来的,里面我采用了IConfigurationSource,ActiveRecord是在web.config里配置的,其实ActiveRecord可以单独写在别的地方或动态配置也是可以的,比如用XML来配置,用Hashtable来配置.下面我简单介绍了怎么配置.
一.用XML配置,通过XmlConfigurationSource来获取配置信息,AppConfig.xml,详细配置请看下面xml数据
1<?xml version="1.0" encoding="utf-8" ?>
2<activerecord>
3 <config>
4 <add
5 key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />
6 <add
7 key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />
8 <add
9 key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
10 <add
11 key="hibernate.connection.connection_string" value="Data Source=.;Initial Catalog=test;Integrated Security=SSPI" />
12 </config>
13</activerecord>
14
XmlConfigurationSource source = new XmlConfigurationSource("http://tech.ddvip.com/appconfig.xml");
二.用Hashtable来实现配置.通过InPlaceConfigurationSource来获取配置信息
1Hashtable properties = new Hashtable();
2properties.Add("hibernate.connection.driver_class", "NHibernate.Driver.SqlClientDriver");
3properties.Add("hibernate.dialect", "NHibernate.Dialect.MsSql2000Dialect");
4properties.Add("hibernate.connection.provider", "NHibernate.Connection.DriverConnectionProvider");
5properties.Add("hibernate.connection.connection_string", "Data Source=.;Initial Catalog=test;Integrated Security=SSPI");
6InPlaceConfigurationSource source = new InPlaceConfigurationSource();
7source.Add(typeof(ActiveRecordBase), properties);
通过上面两种方式来配置ActiveRecord都是可以的,具体怎么用看个人爱好和习惯了,我比较喜欢第二种,用Hashtable,在一般的应用中其实体现不出差距,前些天我在公司写一个通用方法的时候才体现出差距,大家应该都很清楚,修改字符串比修改XML方便是吧,就拿上面的"Data Source=.;Initial Catalog=test;Integrated Security=SSPI"数据库连接字符串来说,如果你把ActiveRecord的配置写在Web.config或是XML文档里,那做程序的时候做一个程序就需要去配置一个web.config节点或是添加一个XML文件,在这里我想到了去写一个通用方法来解决这个问题,当我需要做程序的时候只需要传入数据库名称和程序的实体数据程序集就可以了,其他的工作都叫给所封装的方法去处理.
ActiveRecord配置封装的解决方案详细介绍请点击下面文章连接
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!