[转]NHibernate配置方法
使用NHibernate2.0.1版本. VS2008,数据库是SQL Server 2005.
1:在web.config,App.config里面配置
  则需要这样实例化Configuration对象。 
  NHibernate.Cfg.Configuration cfg = new NHibernate.Cfg.Configuration(); 
  这种配置方法将会到应用程序配置文件(App.Config,Web.Config)中查找NHibernate的配置信息. 
  2:hibernate.cfg.xml 
  建立名为hibernate.cfg.xml的文件。实例化Configuration config = new Configuration().Configure();这样NHibernate将会在目录下寻找hibernate.cfg.xml的配置文件。 
  hibernate.cfg.xml的格式 
  指明配置文件 
  Configuration config = new Configuration().Configure(configFileName); 
  这种配置方法将查找指定的Hibernate标准配置文件,可以是绝对路径或者相对路径。还可以通过编码的方式来添加配置信息: 
  IDictionary props = new Hashtable(); 
  props[“dialect”] = "NHibernate.Dialect.MsSql2005Dialect"; 
... 
  Configuration cfg = new Configuration(); 
  cfg.Properties = props;//cfg.AddProperties(props); 
  VS2008里面NHibernate的智能感应: 
在NHibernate的源代码项目中,在src\NHibernate这个目录下,把nhibernate-mapping.xsd,nhibernate-configuration.xsd,nhibernate-generic.xsd拷贝到: 安装目录的Microsoft Visual Studio 9.0\Xml\Schemas下面.这样,在进行NHibernate的配置时候就可以有提示了.
PS:使用的时候,发现个奇怪的问题.问题如下:
代码:
_session.CreateQuery("FROM Users").List<Users>();
会报:in expected: <end-of-text> (possibly an invalid or unmapped class name was used in the query 这个样的异常.
在网上找解决方法,发现有很多人都是这样问题.有人说把users.hbm.xml改成"嵌入的资源"就可以了.但是,实际根本不行,我的映射文件本来就是设置的是""嵌入的资源".
如果使用以下代码:
ICriteria critera=_session.CreateCriteria(typeof(Users));
critera.List();
这样写就是对的.
真不晓得是怎么搞的!
本文转自:http://blog.csdn.net/canduecho/archive/2009/04/13/4070954.aspx ,其中部分做了修改.
 
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号