前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >NHibernate教程

NHibernate教程

作者头像
全栈程序员站长
发布于 2022-09-14 08:10:07
发布于 2022-09-14 08:10:07
3910
举报

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

一、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

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年7月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
Hibernate_day03总结
Hibernate_day03总结 今日内容 l Hibernate的检索方式 l Hibernate的抓取策略 l Hibernate的批量检索 l 事务的并发问题 1.1 上次课内容回顾: Hibernate的持久类三种状态: * 瞬时态:没有唯一标识OID,没有被session管理 * 持久态:有唯一标识OID,被session管理 * 脱管态:有唯一标识OID,没有被session管理. * 状态转换: 瞬时态:new 获得. * 瞬时à持久:save/saveOrUpdate * 瞬时à脱管:
Java帮帮
2018/03/19
1.1K0
Hibernate_day03总结
Hibernate_day04总结
更多资源分享就在【Java帮帮】微信公众号与QQ空间 Hibernate_day04总结 今日内容 l Hibernate的二级缓存 1.1 上次课内容回顾: Hibernate的检索方式 * 对象导航的方式:customer.getOrders() * OID检索方式:get/load * HQL检索: * 简单查询:from Customer * 别名查询:from Customer as c * 多态查询:from java.lang.Object * 排序查询:from Customer ord
Java帮帮
2018/03/19
6450
Hibernate_day04总结
走进JavaWeb技术世界13:Hibernate入门经典与注解式开发
本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看
Java技术江湖
2019/10/24
1.8K0
hibernate系列之二
持久化:将程序数据在持久状态和瞬时状态间转换的机制;即将内存的数据永久存在关系型数据库中;
沁溪源
2020/09/03
4650
hibernate笔记加强版「建议收藏」
hibernate事实上就是ormapping框架,此框架的作用就是简单话数据库的操作。
全栈程序员站长
2022/07/10
1.1K0
Hibernate文件配置
映射需要通过XML的配置文件来完成,这个配置文件尽量统一(xxx.hbm.xml) Hibernate核心的配置:必须的配置、可选的配置、映射文件的引入
用户3112896
2019/09/26
4280
Hibernate文件配置
hibernate笔记(四)
3) HQL查询, Hibernate Query language hibernate 提供的面向对象的查询语言。
HUC思梦
2020/09/03
6990
Hibernate第三天:Hibernate的一对多配置、Hibernate的多对多的配置
* * 前提:一对多的双方都设置cascade="save-update"
AlbertYang
2020/09/08
1.9K0
Hibernate第三天:Hibernate的一对多配置、Hibernate的多对多的配置
Hibernate二级缓存的使用「建议收藏」
SessionFactory 级别缓存 —- 二级缓存(进程范围)
全栈程序员站长
2022/08/31
1.3K0
Hibernate二级缓存的使用「建议收藏」
SSH框架之Hibernate第一篇
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
海仔
2019/09/18
5840
Hibernate中的一级缓存
在一个会话的生命期里面,他所用到的数据会使用缓冲的,第一次读的是编号为2的数据记录
Hongten
2018/09/18
4570
Hibernate Session 概述
Hibernate是一个优秀的开源对象关系映射(ORM)框架,它提供了一种以面向对象的方式操作数据库的方法。在Hibernate中,Session是与数据库交互的主要接口之一。
堕落飞鸟
2023/05/15
4240
Hibernate HQL 语句
import java.util.Iterator; import java.util.List; import java.util.Map;
Hongten
2018/09/18
6260
Hibernate_day02总结
Hibernate_day02总结 今日内容 l Hibernate持久化对象的状态 l Hibernate的一级缓存 l Hibernate操作持久化对象的方法 l Hibernate 关联关系映射 1.1 上次课内容回顾: Hibernate框架的概述. * 什么是Hibernate * 持久层的ORM框架. * ORM:对象关系映射. * 常见的持久层框架 * JPA * Hibernate * Mybatis * JdbcTemplate * Hibernate流行版本: * 3.x和4.x H
Java帮帮
2018/03/19
1.5K0
Hibernate_day02总结
day32_Hibernate学习笔记_04
  缓存(Cache):是计算机领域非常通用的概念。它介于应用程序和永久性数据存储源(如硬盘上的文件或者数据库)之间,其作用是降低应用程序直接读写硬盘(永久性数据存储源)的频率,从而提高应用的运行性能。缓存中的数据是数据存储源中数据的拷贝。缓存的物理介质通常是内存。   缓存:程序 <-- (内存) --> 硬盘
黑泽君
2018/10/11
9900
day32_Hibernate学习笔记_04
day31_Hibernate学习笔记_03
在数据库表中如何表达多对多关系:   使用中间表,分别引用两方的ID。 在对象中如何表达多对多关系:   两方都使用集合表达。 在配置文件中如何表达一对多关系:
黑泽君
2018/10/11
2.5K0
day31_Hibernate学习笔记_03
[Java面试八]Hibernate总结以及在面试中的一些问题.
1.为什么要使用Hibernate开发你的项目呢?Hibernate的开发流程是怎么样的? 为什么要使用 ①.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。
一枝花算不算浪漫
2018/05/18
1.6K0
Hibernate第二天:Hibernate的一级缓存、其他的API
持久化,将内存中的一个对象持久化到数据库的过程。Hibernate框架就是用来进行持久化的框架。
AlbertYang
2020/09/08
7030
hibernate框架中对象的状态
increment:hibernate先会查询数据最大id值,然后在最大值加1在进行保存操作。 hibernate:select max(id) from t_user; insert into
全栈程序员站长
2022/06/30
8580
SSH框架之Hibernate第二篇
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
海仔
2019/09/18
5230
相关推荐
Hibernate_day03总结
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文