·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> 【转载】ADO.NET与ORM的比较(2):NHibernate实现CRUD
【转载】ADO.NET与ORM的比较(2):NHibernate实现CRUD 转自周公
说明:个人感觉在java领域大型开发都离不了ORM的身影,所谓的SSH就是SPRing+Struts+Hibernate,除了在学习基础知识的时候被告知可以使用JDBC操作数据库之外,大量的书籍中都是讲述使用Hibernate这个ORM工具来操作数据。在.NET中操作数据库的方式有多种,除了最直接的方式就是使用ADO.NET之外,还可以使用NHibernate这个Hibernate在.NET中的实现ORM,如果你对第三方的ORM持怀疑态度,你还可以使用来自微软的实现、根正苗红的Linq或者EntityFramework。大部分从早期就开始使用.NET开发的程序员可能对ADO.NET有种迷恋,使用ADO.NET可以充分将我们早期的SQL知识发挥得淋漓尽致,并且出于对性能的考虑,有些人对.NET中的ORM还保持一种观望态度,包括我自己也是这种态度。不过即使在实际开发中不用,并不代表我们不能去了解和比较这些技术,任何事物的出现和消亡总有其原因的,我们可以了解它们的优点和长处。所以本人抽出了几个周末的时间分别用ADO.NET、NHibernate、Linq和EntityFramework来实现对数据库单表数据的创建、读取、更新和删除操作,也就是所谓的CRUD(C:Create/R:Read/U:Update/D:Delete)。通过实现相同功能的比较,大家自己判断那种方式更适合自己。需要说明的是,如果在VS2008中使用EntityFramework就需要安装VS2008SP1。在本篇周公将讲述如何利用NHibernate实现CRUD功能,为了便于对比,在本次中采用与上次同样的数据库和表,并且也实现同样的功能。NHibernate是一个ORM框架,所谓ORM就是Object Relational Mapping,是一种将关系型数据库中的数据与面向对象语言中对象建立映射关联的技术,我们可以想操作对象一样操作数据,NHibernate将我们对对象的变更保存到数据库中去,并且还负责以对象的方式从数据库中查询数据,这样就可以使开发人员从处理SQL和ADO.NET上节省一些时间和精力用于处理业务逻辑。1、准备首先我们需要从网上下载NHibernate框架,这个可以到它的官方网站www.nhibernate.org上去下载,在周公写这篇文章的时候从网上能下载到的最新版本为2.1.2.GA。如果下载的是压缩包,请将压缩包解压,将会看到四分文件夹,它们的名称和作用分别如下:Configuration_Templates:存放NHibernate连接数据库的配置文件的示例,在这个文件夹下分别有连接Firebird、SQL Server、MySQL、Oracle、PostgreSQL和SQLite数据库的配置示例,可以根据实际所使用的数据库选择示例中的代码并更改其中的数据源即可。Required_Bins:存放NHibernate运行过程中所需要的类库文件,其中还包含了第三方的开源日志框架Log4Net,在不确定到底会使用那些类库的条件下建议将这个文件夹下所有的dll文件拷贝到项目的bin文件夹下。Required_For_LazyLoading:存放延时加载特性支持所需的框架文件,在这个文件夹下提供了三种实现,选择一种将其下所有的dll文件拷贝到项目所在的bin文件夹下。在本示例中选择了Castle。Tests:存放测试用文件,在此文件夹下还有一个名为ABC.hbm.xml的文件,这是一个数据表对应的配置文件的示例,在这个文件夹下的文件我们都用不着,不过在以后我们会用到.hbm.xml文件。2、创建项目我们创建一个项目,项目类型可以根据情况选择,因为我今后要使用NUnit来对项目进行单元测试,所以创建的类库项目。创建项目成功之后将如下文件拷贝到项目的bin目录下:Antlr3.Runtime.dllCastle.Core.dllCastle.DynamicProxy2.dllIesi.Collections.dlllog4net.dllNHibernate.ByteCode.Castle.dllNHibernate.dll然后在项目中添加对这些dll的引用,如下图所示:3、编写代码3.1创建NHibernate配置文件NHibernate的配置文件有相对比较固定的格式,这个可以从下载到框架文件压缩包解压得到,位于Configuration_Templates文件夹下。向当前项目添加一个名为hibernate.cfg.xml的xml文件,在周公的机器上这个文件的格式内容如下:
<?xml version="1.0" encoding="utf-8" ?> <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2" > <session-factory> <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property> <property name="connection.connection_string"> Data Source=zhou;Initial Catalog=aspNetStudy;User ID=sa;PassWord=jerry; </property> <property name="adonet.batch_size">10</property> <property name="show_sql">true</property> <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property> <property name="use_outer_join">true</property> <property name="command_timeout">10</property> <property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property> <property name="proxyfactory.factory_class"> NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle </property> <mapping assembly="NHibernateDemo"/> </session-factory> </hibernate-configuration>View Code
如果你也是使用SQL Server2005作为数据库的话,那么需要更改connection.connection_string中的数据库连接信息为你本机的连接信息,并且实际情况更改assembly的值为你当前项目编译后的程序集名称。在这里还需要注意的是需要将hibernate.cfg.xml的属性更改为复制属性改为始终复制,如下图所示:3.2创建映射文件映射文件包含了对象/关系所需要的元数据,其中包含了所使用的持久化类和到数据库的映射。NHibernate就是通过映射文件知道怎样加载和存储持久化对象。在项目中增加一个名为UserInfo.hbm.xml的xml文件,这个xml文件的内容如下:
<?xml version="1.0" encoding="utf-8" ?> <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NHibernateDemo" namespace="NHibernateDemo"> <class name="UserInfo"> <id name="UserId" column="UserId"> <generator class="native"/> </id> <property name="UserName"/> <property name="RealName"/> <property name="Age"/> <property name="Sex"/> <property name="Mobile"/> <property name="Phone"/> <property name="Email"/> </class> </hibernate-mapping>View Code
注意:如果想要获得在编辑hibernate.cfg.xml或者UserInfo.hbm.xml时的智能提示,可以将下载NHibernate压缩包中的nhibernate-configuration.xsd和nhibernate-mapping.xsd文件拷贝到VS的一个特殊文件夹中,在本机上周公在C盘安装了VS2008,那么需要将上面提到的文件拷贝到C:/Program Files/Microsoft Visual Studio 9.0/Xml/Schemas目录下,你需要根据你的实际情况来拷贝。需要更改这个文件的属性,改为“嵌入的资源”,如下图所示:3.3创建持久化类在当前项目中创建一个名为UserInfo.cs的类文件,这个类的代码如下:
using System; using System.Collections.Generic; using System.Text; namespace NHibernateDemo { /// <summary> /// 数据库中UserInfo表的持久化类 /// 作者:周公 /// 博客地址:http://blog.csdn.net/zhoufoxcn /// 日期:2010-03-19 /// </summary> public class UserInfo { public virtual int UserId { get; set; } public virtual string UserName { get; set; } public virtual string RealName { get; set; } public virtual int Age { get; set; } public virtual bool Sex { get; set; } public virtual string Mobile { get; set; } public virtual string Phone { get; set; } public virtual string Email { get; set; } } }View Code
注意:NHibernate通过使用属性的getter和setter操作来实现对象的持久化,并且要求类不能为sealed,方法和属性必须为virtual。3.4编写辅助类通过上面的文件NHibernate就可以实现关系映射了,这里编写相关的辅助类代码,如下:
using System; using System.Collections.Generic; using System.Text; using Iesi.Collections; using NHibernate; using NHibernate.Cfg; namespace NHibernateDemo { /// <summary> /// 说明:这个类是为了演示NHibernate中的CRUD的用法 /// 作者:周公(周金桥) /// 日期:2010-03-07 /// </summary> public class NHibernateCRUD { private ISessionFactory sessionFactory; public NHibernateCRUD() { sessionFactory = new Configuration().Configure().BuildSessionFactory(); } public ISession GetSession() { return sessionFactory.OpenSession(); } /// <summary> /// 统计用户总数 /// </summary> /// <returns></returns> public int Count() { #region 方法一 //ISession session = GetSession(); //ISQLQuery query = session.CreateSQLQuery("select count(1) from UserInfo"); //int count = query.List<int>()[0]; //sessi