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有些不同。