科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道NHibernate快速指南续

NHibernate快速指南续

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

NHibernate 从数据库底层来持久化你的.Net 对象到关系型数据库。

作者:ghost 来源:CSDN 2007年9月24日

关键字: ghost NHibernate 指南

  • 评论
  • 分享微博
  • 分享邮件

在本页阅读全文(共2页)

第四步:为你的数据库产生一个配置文件

我们至今还没有告诉NHibernate 去哪里连接数据库。最直接的办法是在你的应用程序的配置文件里设置一个NHibernate配置节。这和在Hibernate里使用属性文件是等价的。如下配置:

 

<?xml version="1.0" encoding="utf-8" ?> 
<configuration> 
<configSections> 
<section name="nhibernate" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.3300.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" /> 
</configSections> 

<nhibernate> 
<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=localhost;initial catalog=nhibernate;Integrated Security=SSPI" 
/> 
</nhibernate> 
</configuration> 

 

上面的例子里用了SqlClient 驱动,在本地连接名称为NHibernate 的数据库,提供用户名和密码。那里有一堆属性你需要调整来确定如何让NHibernate来访问数据库。再次说明,你可以在文档里获取更多信息。

请注意以上的配置里并没有涉及到log4net的配置信息。NHibernate使用log4net来记录内部发生的一切。在一个应用程序产品里,在你特定环境里,我推荐配置log4net,并为NHibernate设置一定的日志级别。

第五步:开始展现 NHibernate 的魔力

 所有艰苦的工作已经完成。你将有以下内容

User.cs ----你需要持久化的C#类

User.hbm.xml ----你的NHibernate映射文件

App.config ---对ADO.NET连接的配置信息(如果你愿意,你可以在代码中实现)。

你的数据库里有一张User表。

 现在可以在你的代码中恰当简洁的使用NHibernate。简化的版本如下

  1. 创建一个Configuration对象
  2. 让Configuration知道你将存储何种类型的对象
  3. 为你选择的数据库创建一个Session对象
  4. Load,Save和Query你的对象
  5. 通过Session的Flush()方法将对象提交给数据库。

 为了让你更清晰,我们来看一些代码。

首先,创建一个 Configuration 对象

Configuration对象能够解析所有.Net对象和后台数据库中的映射关系。

 Configuration cfg = new Configuration();
cfg.AddAssembly("NHibernate.Examples");

Configuration对象会搜索装配件里的任何以hbm.xml 结尾的文件。还有其他方法加载映射文件,但这种方式是最简单的。

下一步,创建一个 Session 对象

ISession对象提供一个到后台数据库的连接,ITransaction对象提供一个可以被NHibernate管理的事务。

 ISessionFactory factory = cfg.BuildSessionFactory();
ISession session = factory.OpenSession();
ITransaction transaction = session.BeginTransaction();

接着来Load, Save和Query你的对象

现在你可以用使用传统的.Net方法来操纵对象。你想保存一个新对象到数据库吗?尝试下面的方法:

 

 User newUser = new User();
newUser.Id = "joe_cool";
newUser.UserName = "Joseph Cool";
newUser.Password = "abc123";
newUser.EmailAddress = "joe@cool.com";
newUser.LastLogon = DateTime.Now;

// Tell NHibernate that this object should be saved
session.Save(newUser);

// commit all of the changes to the DB and close the ISession
transaction.Commit();
session.Close();

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章