NHibernate Step by Step (三) Configuration和Sessionfactory(转)

NHibernate Step by Step () ConfigurationSessionfactory

好了,我们再从头看一看Configuration,是否只能从App.config中取配置信息??

当然不是了,以下是3种最常见的配置:

<1> Configuration config = new Configuration();

这种配置方法将会到应用程序配置文件(App.Config,Web.Config)中查找NHibernate的配置信息,NHibernate的配置节必须符合应用程序配置文件个格式,前面的教程我们已经看到过了。

<2> Configuration config = new Configuration().Configure();

       这种配置方法将会在应用的相同目录查找名为”hibernate.cfg.xml”的标准Hibernate配置

       文件,格式如下:

        <3> Configuration config = new Configuration().Configure(configFileName);

None.gif <? xml version="1.0" encoding="utf-8"  ?>
None.gif
< hibernate-configuration   xmlns ="urn:nhibernate-configuration-2.0"   >
None.gif
None.gif       
< session-factory  name ="MySessionFactory" >
None.gif
None.gif              
<!--  properties  -->
None.gif              
< property  name ="connection.provider" > NHibernate.Connection.DriverConnectionProvider </ property >
None.gif              
< property  name ="connection.driver_class" > NHibernate.Driver.SqlClientDriver </ property >
None.gif              
< property  name ="connection.connection_string" > Server=localhost;initial catalog=Hibernate;Integrated Security=SSPI </ property >
None.gif              
< property  name ="show_sql" > false </ property >
None.gif              
< property  name ="dialect" > NHibernate.Dialect.MsSql2000Dialect </ property >
None.gif              
< property  name ="use_outer_join" > true </ property >
None.gif              
< property  name ="query.substitutions" > true 1, false 0, yes 'Y', no 'N' </ property >
None.gif
None.gif              
<!--  mapping files  -->
None.gif              
< mapping  assembly ="Test.Model"   />
None.gif       
</ session-factory >
None.gif
</ hibernate-configuration >
None.gif
None.gif


      

       这种配置方法将查找指定的Hibernate标准配置文件,可以是绝对路径或者相对路径。

       另外我们还可以通过编码的方式添加配置信息:

              这种方式不够配置文件来的灵活,所以我们一般不建议使用。

None.gif Hashtable props  =   new  Hashtable();
None.gifprops[“dialect”] 
=  xxxx;
None.gif
None.gif
None.gif
None.gifconfig.Properties 
=  props;

 

 

在取得config后,我们还需要进行映射文件添加,同样,我们常用以下3种不同的方法:

<1> config.AddXmlFile(“Person.hbm.xml”);

<2> config.AddClass(typeof(Test.Model.Person));

<3> config.AddAssembly(“Test.Model”);

以上方法都可以用“阶梯式“的编码风格,如下:

       

 

None.gif config.AddXmlFile(“Person.hbm.xml”)
None.gif
None.gif      .AddXmlFile(“User.hbm.xml”)
None.gif
None.gif      .AddClass(
typeof (Test.Model.Customer));

 

当然,为了方便起见,我们一般把所有的影射类文件及xml文件统一放在一个程序集中,然后使用config.AddAssembly(assemblyName)的方式,让NHibernate自动去查找指定程序集中所有的映射文件和映射类。

你有没有发现在我们使用标准的hibernate配置文件时,有如下一个元素:

<!-- mapping files -->

<mapping assembly="Test.Model" />

对了,你想的不错,我们可以避免在代码中捆绑映射程序集,而在配置文件中指定,这种方式可以说是最灵活的了。

提示:在Web程序中,最好将配置文件改为config的后缀,否则在没有添加对xmlasp.net映射的情况下,你的配置文件就有可能被下载哟!!

 

我们再来看看Sessionfactory

  

None.gif ISessionFactory sessionFactory  =  config.BuildSessionFactory();

 

在由Configuration构造完SessionFactory后,SessionFactory便保留了配置信息而不再需要Configuration,之后Configurationd的任何变化都不会影响到已经创建好的SessionFactory,如果你的配置信息发生变化,那么,毋庸置疑,你必须重新由Configuration构造出一个新的SessionFactory来。

注意:SessionFactory是一个Heavy Object,它不但保存了配置信息,而且还有所有的映射关系(你可以调用GetAllCollectionMetadata方法试验一下),以及需要进行总体维护的缓存等等信息,所以,我们不应该重复地创建SessionFactory对象,而应该充分共用已经创建出来的SessionFactory对象,同时,SessionFactory也是一个线程安全的对象,所以在多线程的场景下也完全可以共用。在我们实际开发中,我们可以在初始化的部分构造一个SessionFactory即可,比如,在一个公共静态类中初始化一个SessionFactoryreadonly常量等等。

 

另外需要注意的是,如果你要对多个数据库进行操作,那么你可以配置针对每个数据库而创建对应的SessionFactory——大部分情况下,一个数据库对应一个SessionFactory足够使用。

 

好了,这一篇就讲这么多,我们下次再接着练习。
任何建议或者批评,请eabluedog@163.com

原文:http://www.cnblogs.com/abluedog/archive/2006/04/17/377630.html

转载于:https://www.cnblogs.com/lyh55/archive/2010/07/08/1773505.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值