Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,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 删除。

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Nhibernate_nhibernate与ef区别
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说Nhibernate_nhibernate与ef区别,希望能够帮助大家进步!!!
Java架构师必看
2022/07/19
6050
C#用NHibernate实现CRUD
hibernate.cfg.xml <?xml version="1.0" encoding="utf-8" ?> <hibernate-configuration xmlns="urn:nhibe
用户7108768
2021/09/22
5120
NHibernate介绍「建议收藏」
现代化大型项目通常使用独立的数据库来存储数据,其中以采用关系型数据库居多。用于开发项目的高级语言(C#、Java等)是面向对象的,而关系型数据库是基于关系的,两者之间的沟通需要一种转换,也就是对象/关系数据库映射(Object/Relational Mapping,简称ORM)。
全栈程序员站长
2022/09/18
7760
NHibernate介绍「建议收藏」
NHibernate总结
现在的项目中数据访问使用的是NHibernate的一个ORM框架,小弟也是在后期加入项目组,之前对NHibernate就一直没有接触过,所以一直在学习NHibernate,都是一些很基础的一些东西,写出来总结一下,作为备忘。
写代码的猿
2019/04/11
9430
NHibernate总结
Nhibernate入门与demo
      学习和使用Nhibernate已经很久了,一直想写点东西和大家一起学习使用Nhibernate。博客园里也有很多大牛写了很多关于Nhibernate入门的文章。其中:李永京的博客http://www.cnblogs.com/lyj/tag/NHibernate/  内容最为丰富。而且在李哥的博客里面学了很多东西,在此致谢!
老马
2022/05/10
3760
Nhibernate入门与demo
Hibernate 关系映射
第 1 章主要讲解了 Hibernate,它是一个开放源代码的对象关系映射框架。通过对JDBC 进行轻量级的对象封装,使 Java 程序员能够随心所欲地使用面向对象的编程思维来操作数据库。作为目前最杰出的 0-R Mapping 框架,Hibernate 的核心是能够支持对象间关系的良好映射。在面向对象设计与实体模型关系中,对象间关系一般包括 4 种:一对一 ( one-to-one)、一对多 ( one-to-many)、多对一(many-to-one)、多对多 (many-to-many)。本章将对一对多、多对一、多对多关联关系进行讲解,了解关联关系的含义以及关联操作的优势。
用户9184480
2024/12/17
900
Hibernate 关系映射
Nhibernate入门与demo 升级版
       在第一篇文章中有几个地方作为第一个Nhibernate入门demo还有很多不足!今天特意写点补充知识!请先阅读:Nhibernate入门与demo
老马
2022/05/10
3170
Nhibernate入门与demo 升级版
SSH框架之旅-hibernate(3)
表 A 中的一条记录只能和表 B 的一条记录,反之亦然。这种关系的表并不常见,因为既然可以存放在两张表中的数据,也可以用一张表来存放。一对一的表关系用于: 1.分割一个含有有许多列的表 2.由于安全性的考虑而隔离了表的某一部分 3.存储一些很容易删除的临时数据,删除这些表就是删除了这些数据 4.存储只应用于主表的一个子集的信息
Wizey
2018/08/30
1.2K0
SSH框架之旅-hibernate(3)
hibernate它5.many2one单向
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/117521.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/06
1420
hibernate它5.many2one单向
NHibernate 缓存
一级缓存就是 ISession 缓存, 在 ISession 的生命周期内可用, 多个 ISession 之间不能共享缓存的对象, 通过 ISessionFactory 创建的 ISession 默认支持一级缓存, 不需要特殊的配置。 在 NHibernate 的参考文档中, 对 ISession 的描述如下:
beginor
2020/08/06
6130
Nhibernate学习之性能改善1
1.学习目标 通过几天来大家对Nhiberate的反映,很多人对它的性能非常的担心,本文便着手从最直观的角度和方法中逐步改善nhiberate的性能。改善性能是需要做出很多分析和测试的,本文试图从最表层的对象入手,以后逐渐增加其他方面的性能分析。希望各位看官莫要着急。 2. 分析: ISession和ISessionFactory对象的产生,使用,和销毁对性能的影响。 ISessionFactory对象是线程安全的,它可以被程序的任意线程所适用,但是创建它的性能开销是比较大的。所以不要频繁创建ISessionFactroy对象 ISession对象是非线程安全的,创建它的开销比较小 创建一个ISessionFactory对象的主要流程有:
全栈程序员站长
2022/08/04
2420
Nhibernate学习之性能改善1
hibernate笔记加强版「建议收藏」
hibernate事实上就是ormapping框架,此框架的作用就是简单话数据库的操作。
全栈程序员站长
2022/07/10
1.1K0
NHibernate 如何对session管理,实现lazy=true
Nhibernate session管理。以前用过Hibernate,由于当时我不是主要负责持久层,所以对Hibernate不是很熟悉,但记得当时session管理没有什么问题。但是NHibernate就出现了一个问题。如果每次进行持久化操作都open一次session然后close一次session,那么将不能使用lazy这个机制。运行时会报错“session已关闭”之类的提示。 怎么解决呢?我查了一些文章得到以下结论。 两个方法: 1.自己写一个sessionFactoryHelper,里边建一个get
用户1258909
2018/07/03
6530
SSH框架之旅-hibernate(4)
QBC 查询是通过 Restrictions 类的静态方法来实现的,具体的方法如下表所示。
Wizey
2018/08/30
1.7K0
SSH框架之旅-hibernate(4)
NHibernate分页
转载:http://www.cnblogs.com/tenghoo/archive/2011/02/14/1954393.html
跟着阿笨一起玩NET
2018/09/19
4730
NHibernate学习笔记之一,Hello world!
NHibernate是一个面向.NET环境的对象/关系数据库映射框架,主要应用在数据持久层,和其它的ORM框架一样用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。Nhibernate 来源于非常优秀的基于Java的Hibernate 关系型持久化框架。Nhibernate支持多种类型的数据库,包括:FireBird、MSSQL、MySql、Oracle、PostgreSQL、SQLite、SybaseASE、SybaseSQLAnywhere。
张果
2022/05/09
6140
NHibernate学习笔记之一,Hello world!
nhibernate的简单配置与使用
配置nhibernate的方式有两种,一种是通过xml文件的方式配置,还有就是通过class的方式配置。网上大多数是以xml的方式配置nhibernate,本文则已class的方式来配置,并通过IOC(依赖注入,本文以构造注入)的方式注册nhibernate。下面就以一个demo来说明配置、注入以及使用的方法。
全栈程序员站长
2022/09/15
5220
nhibernate的简单配置与使用
C# 数据操作系列 - 10 NHibernate初试
在上一篇基本讲完了EF Core的入门级教程。从这一篇开始,我们试着去探索一下 .net core平台上更多的ORM框架。那么,这一篇开始我们就来试试NHibernate。
程序员小高
2020/05/21
8670
NHibernate详解
NHibernate 是一个基于.Net 的针对关系型数据库的对象持久化类库。Nhibernate 来源于非常优秀的基于Java的Hibernate 关系型持久化工具。 NHibernate 从数据库底层来持久化你的.Net 对象到关系型数据库。NHibernate 为你处理这些,远胜于你不得不写SQL去从数据库存取对象。你的代码仅仅和对象关联,NHibernat 自动产生SQL语句,并确保对象提交到正确的表和字段中去。
全栈程序员站长
2022/09/18
7150
[原创]Fluent NHibernate之旅二--Entity Mapping
接着上一篇,今天我们说说ORM中的Mapping。如果你要体验NHibernate的强大,首先你就要学会配置,包括SessionFactory和Mapping的配置。今天跟上一篇一样,会使用传统方式和 NHibernate 进行讲解。如果你要亲手试验一下,可以先看一下“Fluent NHibernate之旅一”,进行一下数据库和SessionFactory的准备。 本节内容: 简单实体映射 使用自定义类型映射实体属性 NHibernate的实体映射(Entity Mapping)做的非常好,虽然不是完美
脑洞的蜂蜜
2018/02/02
1.1K0
[原创]Fluent NHibernate之旅二--Entity Mapping
相关推荐
Nhibernate_nhibernate与ef区别
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文