当前位置: 首页 > 工具软件 > NHibernate > 使用案例 >

nhibernate使用

谭昕
2023-12-01
使用步骤

1. 建立库表

2. 建立映射对象

3. 建立映射文件

4. 编写配置文件

5. 编写程序

详细说明

1. 建立库表

 库:    test
   表:    userinfo
   字段:uid char(10), pwd char(20) uid为主键

2. 建立映射对象

using System;

namespace testNHibernate
{
 /// <summary>
 /// UserInfo 的摘要说明。
 /// </summary>
 public class UserInfo
 {

  #region 域

  private string _userName;
  private string _password;

  #endregion

  #region 属性

  public string userName
  {
   get
   {
    return _userName;
   }
   set
   {
    _userName = value;
   }
  }

  public string password
  {
   get
   {
    return _password;
   }
   set
   {
    _password = value;
   }
  }

  #endregion
  #region 方法

  public UserInfo()
  {
   //
   // TODO: 在此处添加构造函数逻辑
   //
  }

  #endregion

 }
}

3. 建立映射文件

<?xml version="1.0" encoding="utf-8" ?>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.0">

 <class name="testNHibernate.UserInfo, testNHibernate" table="userinfo">
  <id name="userName" column="uid" type="String" length="10">
   <generator class="assigned" />
  </id>
  
  <property name="password" column="pwd" type="String" length="20"/>
 </class>
 
</hibernate-mapping>

说明:class元素中的class与hibernate中有些不同,除了名字空间,类名外,后面有个集合名,这个集合名不能随便写,一般写名字空间就可以了。具体有什么限制查找中

4. 编写配置文件

    在web.config或app.config中加入

  <configSections>
 
 <section name="nhibernate" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />
 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
 
  </configSections>
   

  <nhibernate>
  <add
   key="hibernate.show_sql"
   value="true"
  />
  <add
   key="hibernate.connection.provider"         
   value="NHibernate.Connection.DriverConnectionProvider"
  />
  <add
   key="hibernate.dialect"                     
   value="NHibernate.Dialect.MsSql2000Dialect"
  />
  <add
   key="hibernate.connection.driver_class"         
   value="NHibernate.Driver.SqlClientDriver"
  />
  <add
   key="hibernate.connection.connection_string"
   value="Server=127.0.0.1;initial catalog=test;User=sa;Password=1234"
  />
  
 </nhibernate>
 
 <log4net debug="false">
  <appender name="LogFileAppender" type="log4net.Appender.FileAppender" >
   <param name="File" value="Blueblog.log" />
   <param name="datePattern" value="MM-dd HH:mm" />
   <param name="AppendToFile" value="true" />
   <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="[blueblog] %-5p [%t] %d %C{1}.%M(%L) | %m%n" />
    
   </layout>
  </appender>
  <root>
   <level value="DEBUG" />
   <appender-ref ref="LogFileAppender" />
  </root>
 </log4net>

说明:log4net的配置并不是必须的。NHibernate的配置中,只有connection_string需要自己调整,看到网上的一些例子用SPPI登录,实验了多次没有成功,在使用用户名时,不要用User ID=xxx 中间一个空格会被不识别。直接用User就可以了。

       加上log4net是很好的习惯,NHibernate的一些运行都会被记录在日志中。有些错误就可以看到。便于解决问题。

5. 编写程序

log4net.ILog log = log4net.LogManager.GetLogger(this.GetType());
   
   try
   {
    
    Configuration cfg = new Configuration();
    
    cfg.AddAssembly("testNHibernate");
    cfg.AddXmlFile("C://Inetpub//wwwroot//testNHibernate//UserInfo.hbm.xml");
    
    ISessionFactory sessionFactory = cfg.BuildSessionFactory();
    ISession session = sessionFactory.OpenSession();
    //ITransaction trans = session.BeginTransaction();
    
    UserInfo user = new UserInfo();
    user.userName = "yfpeng6";
    user.password = "yfpeng";
    session.Save(user);
    //trans.Commit();
    session.Flush();

    session.Close();
    
   }
   catch(Exception ex)
   {
    Response.Write("<p>" + ex.Message);
    log.Error(ex.Message);
   }

说明:具体的操作和hibernate相同,只是下面两句

    cfg.AddAssembly("testNHibernate");
    cfg.AddXmlFile("C://Inetpub//wwwroot//testNHibernate//UserInfo.hbm.xml");


    在我的这次测试中,nhibernate并没有在配置文件中把hbm写入其中。而是在这一一加载。(但我想应该也在在配置文件中加载的方法,测试中)。还有AddAssmbly参数为映射文件中class后面的那个集合,具体为什么这样还是不太明白。

6. 总结

编写这个测试程序时,遇到不少问题,主要是配置和hibernate有些不同。 

 类似资料: