NHibernate教程

NHibernate教程 一、NHibernate简介在今日的企业环境中,把面向对象的软件和关系数据库一起使用可能是相当麻烦、浪费时间的。NHibernate是一个面向.Net环境的对象/关系数据库映射工具。对象/关系数据库映射(object/relationalmapping(ORM))这个术语表示一种技术,用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。NHibernate除了能将一张表映射为

大家好,又见面了,我是你们的朋友全栈君。

 一、NHibernate简介

在今日的企业环境中,把面向对象的软件和关系数据库一起使用可能是相当麻烦、浪费时间的。NHibernate是一个面向.Net环境的对象/关系数据库映射工具。对象/关系数据库映射(object/relational mapping (ORM))这个术语表示一种技术,用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。
NHibernate除了能将一张表映射为一个对象,还可以将表间关系变为对象的属性。例如学生和课程间的多对多关系就可以转化为学生类中的一个课程集合的属性。由此可见,NHibernate不仅仅管理.Net类到数据库表的映射,还提供数据查询和获取数据的方法。因此采用NHibernate,可以大幅度减少开发时人工使用SQL处理数据的时间。

二、NHibernate使用步骤

1.为系统引入NHibernate的库,并且配置NHibernate;
2.新建一个将要持久化.Net对象的表;
3.构建一个需要被持久化的.Net类;

4.构建一个可以让NHibernate知道如何完成ORM映射的XML文件;
5.使用NHibernate的API来编程

三、NHibernate的使用

1. 配置NHibernate

(1)NHibernate的配置文件有两种:在桌面应用程序(WinForm)中为App.config,在网页应用程序(WebForm)中为web.config。两种方法要添加的配置信息是一样的,目标都是告诉NHbiernate使用什么样的数据库,使用哪个库,用户密码分别是什么。

如果使用的是WinForm,将如下文本保存为App.config放到程序启动目录就可以。如果是WebForm,则将下面的文本添加到web.config中

<?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” />
         <!–连接数据方言最常用的是MsSql2000Dialect –>
         <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=”workstation id=BILLGATES;packet size=4096;integrated security=SSPI;initial catalog=CAW;persist security info=False” />
      </nhibernate>
   </configuration>

(2)然后将NHibernate唯一的一个dll(NHibernate.dll)添加到工程的引用中,步骤如下:
à   à

2. 创建一个用于测试的表
这里需要创建3张表,分别用于保存:学生、课程、选课信息。可以用Sql语句来创建,也可以用其他方式创建。创建表的Sql语句如下:

CREATE TABLE Student (

StudentId int identity (1, 1) PRIMARY KEY NOT NULL,

StudentName nvarchar(40) default NULL,

StudentPassword nvarchar(20) default NULL,

EmailAddress nvarchar(40) default NULL,

DateCreated datetime default NULL

)

CREATE TABLE Course (
CourseId int identity (1, 1) PRIMARY KEY NOT NULL,
CourseName nvarchar(40) default NULL,
DateCreated datetime default NULL
)

CREATE TABLE StudentCourse (
StudentCourseId int identity (1, 1) PRIMARY KEY NOT NULL,
StudentId int,
CourseId int,
DateCreated datetime default NULL
)

产生的三张表的结构如下所示:
3. 创建.Net类和与其对应的XML文件
(1)       单表的情况
单表的情况就是指该表没有和其他表有关联的情况。这样情况下,可以用软件来辅助产生类和对应的XML文件。在这里,仍然采用手写的方式来生成这两个文件。对于课程表,需要写的类和XML如下所示:
类文件(Course.cs)
using System;
namespace NHibernateTest{

         public class Course{

                   public Course(){}
                   private int courseId;
                   private string courseName;
           private DateTime dateCreated;
                   public int CourseId{

                            get { return courseId; }
                            set { courseId = value; }
                   }
                   public string CourseName{

                            get { return courseName; }
                            set { courseName = value; }
                   }

                   public DateTime DateCreated{

                            get { return dateCreated; }
                            set { dateCreated = value; }
                   }
         }
}

 

XML文件(Course.hbm.xml)
<?xml version=”1.0″ encoding=”utf-8″ ?>
<hibernate-mapping xmlns=”urn:nhibernate-mapping-2.0″>
         <class name=”NHibernateTest.Course, NHibernateTest” table=”Course”>
                   <id name=”CourseId” column=”CourseId” type=”Int32″>
                            <generator class=”native” />
                   </id>
                   <property name=”CourseName” column= “CourseName” type=”string” length=”40″/>
                   <property name=”DateCreated” type=”DateTime” length=”8″/>
         </class>
</hibernate-mapping>

(2)       含有关系的表的情况
含有关系的表指的是像学生这样,除了保存学生的基本信息,还希望把选课信息保存到学生的类中。这样情况下不能用软件来辅助产生对应的类和XML,这是NHibernate中唯一需要费脑筋学的地方。学生表对应的类和XML如下所示:
类文件(Student.cs)
using System;

using Iesi.Collections;

namespace CodeTest{

         public class Student{

                   public Student(){}

                   private int studentId;

                   private string studentName;

                   private string studentPassword;

                   private string emailAddress;

                   private DateTime dateCreated;

                   private ISet courses =

new HashedSet();

                   public int StudentId{

                            get { return studentId; }

                            set { studentId = value; }

                   }

                   public string StudentName{

                            get { return studentName; }

                            set { studentName = value; }         }

                   public string StudentPassword{

                            get { return studentPassword; }

                            set { studentPassword = value; }                   }

                   public string EmailAddress{

                            get { return emailAddress; }

                            set { emailAddress = value; }}

public DateTime DateCreated{

                            get { return dateCreated; }

                            set { dateCreated = value; }}

                   public ISet Courses{

                            get{return courses;}

                            set{courses=value;}

                   }               

         }

}

XML文件(Student.hbm.xml)

<?xml version=”1.0″ encoding=”utf-8″ ?>

<hibernate-mapping xmlns=”urn:nhibernate-mapping-2.0″>

         <class name=”NHibernateTest.Student, NHibernateTest” table=”Student”>

                   <id name=”StudentId” column=”StudentId” type=”Int32″>

                            <generator class=”native” />

                   </id>

                   <property name=”StudentName” column= “StudentName” type=”string” length=”40″/>

                   <property name=”StudentPassword” type=”string” length=”20″/>

                   <property name=”EmailAddress” type=”String” length=”40″/>

                   <property name=”DateCreated” type=”DateTime” length=”8″/>

                  <set name=”Courses” table=”StudentCourse” inverse=”false”>

                   <key column=”StudentID”/>

                   <many-to-many column=”CourseID” class=” NHibernateTest.Course, NHibernateTest “/>

                   </set>

</class>

</hibernate-mapping>

4. 使用NHibernate的API进行编程

数据库编程不外乎“添加”、“删除”、“更新”,看看NHibernate是如何实现这三种操作吧。

(1)       在类中声明NHibernate的Factory

private static Configuration mCfg=new Configuration();
private static NHibernate.ISessionFactory SessionFactory=null;

(2)       在系统初始化的时候加载XML,并创建Factory

mCfg.AddXmlFile( ApplicationPath +”/Course.hbm.xml”);
mCfg.AddXmlFile( ApplicationPath +”/Student.hbm.xml”);

SessionFactory=mCfg.BuildSessionFactory();

(3)       使用HSql查询

string hsql=”from Student where StudentName=’kexd'”;

ISession vSession= SessionFactory.OpenSession();

IQuery query = vSession.CreateQuery(hsql);

IList list = query.List();

if(list.Count>0){

   Student obj=(Student)list[0];

   //…..

}

vSession.Close();

(4)       根据主键查询

int studentID=1;

ISession vSession= SessionFactory.OpenSession();

Student obj=(Student) vSession.Load(typeof(Student),studentID);

vSession.Close();

(5)       插入

Student obj=new Student();

obj.StudentName=”wuyang”;

obj.StudentPassword=”helloWorld”;

ITransaction vTransaction = vSession.BeginTransaction();

try

{

   vSession.Save(obj);

   vTransaction.Commit();

}

catch(Exception)

{

   vTransaction.Rollback();

}

vSession.Close();

(6)       更新

ISession vSession= Config.SessionFactory.OpenSession();

IQuery query = vSession.CreateQuery(“from Student where StudentName=’kexd'”);

IList list = query.List();

ITransaction vTransaction = vSession.BeginTransaction();

try

{

   foreach(Student obj in list)

   {

      obj.EmailAddress=”kesfzu@21cn.com“;

      vSession.Save(obj);

   }

   vTransaction.Commit();

}

catch(Exception)

{

   vTransaction.Rollback();

}

finally

{

   vSession.Close();

}

(7)       删除ISession vSession= Config.SessionFactory.OpenSession();
IQuery query = vSession.CreateQuery(“from Student where StudentName=’kexd'”);
IList list = query.List();
ITransaction vTransaction = vSession.BeginTransaction();
try
{

   foreach(Student obj in list)
   {

           vSession.Delete(obj);
   }
   vTransaction.Commit();
}
catch(Exception)
{

   vTransaction.Rollback();
}
finally
{

   vSession.Close()

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/andywang110001/archive/2009/05/15/4189079.aspx

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/158268.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 用户路径的分析结果_用户账号文件的路径

    用户路径的分析结果_用户账号文件的路径1.什么是用户路径分析用户行为分析是数据分析中非常重要的一项内容,在统计活跃用户,分析留存和转化率,改进产品体验、推动用户增长等领域有重要作用。单体洞察、用户分群、行为路径分析是用户行为数据分析的三大利器。用户路径分析,就是用户在APP或网站中的访问行为路径。用户行为路径分析是互联网行业特有的一类数据分析方法,它主要根据每位用户在App或网站中的点击行为日志,分析用户在App或网站中各个模块的流转规律与特点,挖掘用户的访问或点击模式,进而实现一些特定的业务用途,如App核心模块的到达率提升、特定用户群

  • 职称计算机考试选什么模块,职称计算机考试如何选择模块?

    职称计算机考试选什么模块,职称计算机考试如何选择模块?原标题:职称计算机考试如何选择模块?众所周知,自从2013年开始,已有所增加,模块数理由原来的22个模块增加到26个考试科目。所以,考生可根据自身基础、平时接触多的或兴趣选择报考科目,按规定参加职称计算机考试的人员必须通过规定的模块数量,因各地区政策不同考生具体可登陆当地人事咨询网次查看,为了让考生更好选择职称计算机考试模块。职称计算机考试中心为考生提供如下参考:一、选择模块的原则:首先,根据考生…

  • altium designer怎么画圆弧_word怎么画小圆形

    altium designer怎么画圆弧_word怎么画小圆形1.概述近期在学PADS这个平台,禁止覆铜区域可以放置各种形状,而在AD一直用的是polygonpourcutout这个选项,似乎不能绘制出圆形呢?别着急,我们接着往下看,AD还是上手比较快的设计软件。2.步骤如上所述,一般我们在AD要禁止覆铜,或者挖去铜皮,一般都用polygonpourcutout:但涉及如下图(蓝色圆圈)这样的禁止覆铜,就不好操作了。…

  • 网游的跨服玩法是如何实现的?“跨域体系”架构设计思路

    网游的跨服玩法是如何实现的?“跨域体系”架构设计思路https://www.fgba.net/sitemap.xml

  • BroadcastReceiver详解以及应用[通俗易懂]

    使用Android手机的时候,我们的手机管家中经常会出现开机自启动某某app,那么对于这个某某APP来说,他是怎么知道系统什么时候开机的呢?还有,系统短信怎么知道收到了短信?以及屏幕点亮与关闭、应用卸载与安装等等。这就讲到了Android四大组件之一:BroadcastReceiver,翻译是广播接收者。意思就是接收广播用的。他可以接收到系统开机完成的广播,以及系统电量不足的广播,以及系统收到短信的

  • cookie登录知乎「建议收藏」

    用cookie登录个人知乎主页步骤:1、用自己账号登录知乎,然后复制下来自己的cookie信息。2、用request.get(url,headers=headers)把cookie传入get请求中3、用BeautifulSoup匹配内容一、用自己账号登录知乎,获取自己的cookie信息。二、构造请求函数,并把cookie信息加入…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号