NHibernate教程1

2024-02-09 17:58
文章标签 教程 nhibernate

本文主要是介绍NHibernate教程1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、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.使用NHibernateAPI来编程

 

三、NHibernate的使用

1. 配置NHibernate

1NHibernate配置文件有两种:在桌面应用程序(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唯一的一个dllNHibernate.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. 使用NHibernateAPI进行编程

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

(1)       在类中声明NHibernateFactory

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();

}

这篇关于NHibernate教程1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/694910

相关文章

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads