Nhibernate 4.0 教程入门
Nhibernate 4.0 教程
目录
1. 下载Nhibernate 4.04. 1
2. 入门教程... 2
3. 测试项目详解... 3
4. 总结... 7
附:关联知识点... 7
知识点1:C#静态构造函数... 7
知识点2:关于Visual Studio文件生成操作... 8
前言:
为什么会有这个框架?这就牵扯进了Java和C#的恩恩怨怨,Java是开源的面向对象语言的代表,围绕Java的有不计其数的开源框架,其中ORM框架(不要问我什么是ORM框架)中的最耀眼的代表就是Hibernate;C#也是Microsoft紧跟在Java后面推出的面向对象的语言,这两个相似度太大了(我读书自己学习的Java,后面C#就没特殊的学习过,直接就进行拿来用了),.NET开发者也参照Hibernate开发了一个针对.NET平台下的ORM 框架,也就是Nhibernate。
开发环境:
Windows 7
Visual Studio 2013
Nhibernate 4.04
Microsoft Sql Server 2012
- 下载Nhibernate 4.04
直接下载 官网地址http://nhibernate.info/(自己下载网速真的好慢)
NHibernate is a mature, open source object-relational mapper for the .NET framework. It's actively developed, fully featured and used in thousands of successful projects.
官网介绍了Nhibernate是针对.NET框架的成熟的、开源的面向关系型数据库映射(ORM).
或者使用VS2013附带的NuGet管理程序直接安装(NuGet,.NET下面一个开源的程序包管理工具):Install-Package Nhibernate(非常的快)

- 入门教程
新建一个项目NHOne和测试程序,并且添加对于该项目的测试项目,项目架构如下:

划重点:其中对于Nhibernate的配置文件(hibernate.cfg.xml与ClassMapping文件,对于生成的操作,必须选择始终复制和嵌入式资源。(不然编译调试的时候会出现bug,比如没有Model Class的Mapping等等)。
- 测试项目详解
3.1 初始化C#解决方案NHOne(控制台应用程序和对应的测试项目)
给每一个项目添加Nhibernate引用,测试项目也需要(直接NuGet命令安装即可)
3.2 编写NHibernate配置文件
在NHOne的根目录下添加hibernate.cfg.xml文件(生成操作嵌入式资源和始终复制),在文档属性中架构选择hibernate-configuration-2.2 & hibernate-mapping-2.2两个文件,这样编写hibernate.cfg.xml就会有自动提示的功能(这两个文件在我们解决方案NHOne的packages/Nhibernate目录中)

hibernate.cfg.xml 具体内容如下:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
<session-factory>
<property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
<property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property>
<property name="connection.connection_string">Data Source=localhost;user=sa;password=12345;Initial Catalog=test</property>
<property name="dialect">NHibernate.Dialect.MsSql2012Dialect</property>
<property name="show_sql">true</property>
<property name="hbm2ddl.auto">update</property>
<!--Mapping files 嵌入式资源 表格table 名字不可以是user-->
<mapping assembly="NHOne"/>
</session-factory>
</hibernate-configuration>
<mapping assembly=”NHOne”/> 这里写的是项目的名字,然后就会搜寻项目下面所有的后缀是.hbm.xml的文件,也可以手动自己添加,比较麻烦,有机会再详细讲解。
3.3 编写Model Class “User”
所有的属性都是使用virtual来修饰(延迟加载有用),添加对应的get set方法
在MSServer 中,user 是关键字,因此不能够有user的表格,可以使用其他来代替
在实际应用中,每一个model类,很可能需要提供Equals() HashCode() ToString()方法的重写
namespace NHOne.Model
{
public class User
{
private string id;
private string username;
private string password;
private char gender; //"F" & "M"
private int age;
private string phone;
public User()
{
}
public User(string username, string password, char gender, int age, string phone)
{
this.username = username;
this.password = password;
this.gender = gender;
this.age = age;
this.phone = phone;
}
public User(string id, string username, string password, char gender, int age, string phone)
{
this.id = id;
this.username = username;
this.password = password;
this.gender = gender;
this.age = age;
this.phone = phone;
}
public virtual string Id { get; set; }
public virtual string Username { get; set; }
public virtual string Password { get; set; }
public virtual char Gender { get; set; }
public virtual int Age { get; set; }
public virtual string Phone { get; set; }
public override bool Equals(object obj)
{
if (this == obj)
{
return true;
}
User user = obj as User;
if (user == null)
{
return false;
}
else
{
return this.Username.Equals(user.Username);
}
}
public override int GetHashCode()
{
return Username.GetHashCode();
}
public override string ToString()
{
return "id:" + Id + "; Username:" + Username + "; Password:" + Password + "; Gender:" + Gender + "; Age:" + Age + "; Phone:" + Phone;
}
}
}
3.4 编写Model的Mapping文件
位于Mapping目录下面新建文件User.hbm.xml文件(嵌入式资源,添加文件的架构为hibernate-mapping-2.2.xml),红色部分 assembly是项目的名称,namespace是在项目中Model类的命名空间,如果省略的话,需要在后面的class name属性中填写完整的名字空间和类名。
注意table的名字不能写成user,否则报错,因为user是数据库的关键字
内容如下:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NHOne" namespace="NHOne.Model" default-lazy="true">
<class name="User" table="client">
<id name="Id">
<column name="user_id" sql-type="char(32)" not-null="true"/>
<generator class="uuid.hex"/>
</id>
<property name="Username" column="username" not-null="true"/>
<property name="Password" column="password" not-null="true" />
<property name="Gender" column="gender" />
<property name="Age" column="age" />
<property name="Phone" column="phone" />
</class>
</hibernate-mapping>
3.5 编写NHibernate的帮助类,初始化NHibernate的环境,获取Session
在Util命名空间下,添加YangNHibernate的类,具体内容如下:
namespace NHOne.Util
{
public class YangNHibernate
{
private static readonly ISessionFactory sessionFactory;
private static string HibernateHbmXmlFileName = "hibernate.cfg.xml";
//private static ISession session
static YangNHibernate()
{
sessionFactory = new Configuration().Configure().BuildSessionFactory();
}
public static ISessionFactory getSessionFactory()
{
return sessionFactory;
}
public static ISession getSession()
{
return sessionFactory.OpenSession();
}
public static void closeSessionFactory()
{
}
}
}
3.6 编写测试代码
在测试类中测试保存User到数据库,使用事务的机制
[TestMethod]
public void TestSaveUser()
{
User user = createUser();
ISession session = YangNHibernate.getSession();
ITransaction tx = session.BeginTransaction();
session.Save(user);
tx.Commit();
session.Close();
}
调试程序:

- 总结
NHibernate是C#程序员,参照Java的ORM框架Hibernate实现的一个开源项目,在C#中项目开发中非常的便捷高效,让程序猿从复杂的SQL语句中解放出来,对于项目的模块化非常好用。
测试项目的源代码地址:
https://github.com/hbhzsysutengfei/NHibernateOne.git
参考文档:
- NHibernate官方网站 http://nhibernate.info/
- MSDN for C#:https://msdn.microsoft.com/zh-cn/library/k9x6w0hc(v=vs.120).aspx
附:关联知识点
知识点1:C#静态构造函数
C#关于静态构造函数的知识,自动调用初始化静态的成员属性,尤其是readonly修饰的静态属性,与Java中的静态代码块类似。
参考MSDN给出的解释:
A static constructor is used to initialize any static data, or to perform a particular action that needs to be performed once only. It is called automatically before the first instance is created or any static members are referenced.
(https://msdn.microsoft.com/zh-cn/library/k9x6w0hc(v=vs.120).aspx)
因为静态构造函数是.NET自动调用的,因此改代码块就无需使用修饰符修饰。
关于C#静态构造函数的特征,具体如下:
A static constructor does not take access modifiers or have parameters.
A static constructor is called automatically to initialize the class before the first instance is created or any static members are referenced.
A static constructor cannot be called directly.
The user has no control on when the static constructor is executed in the program.
A typical use of static constructors is when the class is using a log file and the constructor is used to write entries to this file.
Static constructors are also useful when creating wrapper classes for unmanaged code, when the constructor can call the LoadLibrary method.
If a static constructor throws an exception, the runtime will not invoke it a second time, and the type will remain uninitialized for the lifetime of the application domain in which your program is running.
知识点2:关于Visual Studio文件生成操作
Visual Studio生成操作有以下几个选项:
Non(无):也就是在项目生成的时候不进行任何的操作,在生成的目录中没有此文件,一般用于项目描述文件.
Content(内容):也就是将文件直接复制到输出目录中,一般用于html等静态文件.
Compile(编译):编译代码文件,通常的代码文件需要编译
Embedded Resource(嵌入式资源):将该文件作为DLL或可执行文件嵌入到主目录中,通常用于资源文件,比如Nhibernate的配置文件等等。
Nhibernate 4.0 教程入门的更多相关文章
- Asp.Net MVC4.0 官方教程 入门指南之五--控制器访问模型数据
Asp.Net MVC4.0 官方教程 入门指南之五--控制器访问模型数据 在这一节中,你将新创建一个新的 MoviesController类,并编写代码,实现获取影片数据和使用视图模板在浏览器中展现 ...
- Asp.Net MVC4.0 官方教程 入门指南之四--添加一个模型
Asp.Net MVC4.0 官方教程 入门指南之四--添加一个模型 在这一节中,你将添加用于管理数据库中电影的类.这些类是ASP.NET MVC应用程序的模型部分. 你将使用.NET Framewo ...
- Asp.Net MVC4.0 官方教程 入门指南之三--添加一个视图
Asp.Net MVC4.0 官方教程 入门指南之三--添加一个视图 在本节中,您需要修改HelloWorldController类,从而使用视图模板文件,干净优雅的封装生成返回到客户端浏览器HTML ...
- Asp.Net MVC4.0 官方教程 入门指南之二--添加一个控制器
Asp.Net MVC4.0 官方教程 入门指南之二--添加一个控制器 MVC概念 MVC的含义是 “模型-视图-控制器”.MVC是一个架构良好并且易于测试和易于维护的开发模式.基于MVC模式的应用程 ...
- Android Studio2.0 教程从入门到精通Windows版
系列教程 Android Studio2.0 教程从入门到精通Windows版 - 安装篇Android Studio2.0 教程从入门到精通Windows版 - 入门篇Android Studio2 ...
- Android Studio2.0 教程从入门到精通Windows版 - 入门篇
http://www.open-open.com/lib/view/open1468121363300.html 本文转自:深度开源(open-open.com)原文标题:Android Studio ...
- 零基础快速入门SpringBoot2.0教程 (二)
一.SpringBoot2.x使用Dev-tool热部署 简介:介绍什么是热部署,使用springboot结合dev-tool工具,快速加载启动应用 官方地址:https://docs.spring. ...
- ECMAScript 6.0基础入门教程
ECMAScript 6.0基础入门教程 转:https://blog.csdn.net/hexinyu_1022/article/details/80778727 https://blog.csdn ...
- Android Studio2.0 教程MAC版 -快捷键篇
本文转至 Android Studio2.0 教程从入门到精通MAC版 - 提高篇 ( OPEN 开发经验库) 第二篇我们开发了一个Hello World应用,并介绍Android Sutdio的界面 ...
随机推荐
- bzoj 3202: [Sdoi2013]项链
Description 项链是人体的装饰品之一,是最早出现的首饰.项链除了具有装饰功能之外,有些项 链还具有特殊显示作用,如天主教徒的十字架链和佛教徒的念珠. 从古至今人们为了美化人体本身,也美 化环 ...
- 跨界玩AR,迪奥、Hugo Boss等知名奢侈品牌将制造AR眼镜
Snapchat因为阅后即焚消息应用而被人所熟知,前段时间这家公司拓展主要业务,未来将不再只有消息应用,还有款名为"Spectacles"的AR太阳镜.内置了一个摄像头,戴上之后即 ...
- ACM : POJ 2676 SudoKu DFS - 数独
SudoKu Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu POJ 2676 Descr ...
- ZooKeeper个人笔记客户端watcher和AsycCallback回调
每一个Watcher具有如下属性: 1.KeeperState 2.EventType 3.path 4.process(WatchedEvent evnet)回掉方法 Watcher干嘛的?用户监听 ...
- Curator leader 选举(一)
要想使用Leader选举功能,需要添加recipes包,可以在maven中添加如下依赖: <dependency> <groupId>org.apache.curator< ...
- VS2013开启滚动条缩略图和双击选中高亮,效果杠杠滴!
1.双击代码或选中代码高亮,用以下插件,反应很灵敏,我安装的是第三个 2.代码编辑器的滚动条缩略图是VS自带的,需要打开菜单----工具----选项,如下图设置: 3.VS默认的选中颜色,需要打开菜单 ...
- JQuery的一些简单功能
JQuery js的缺点总结 1.入口函数只能有一个,如果出现多个,后面的会覆盖掉前面的 2.代码容错性差,容易出错,出错会导致后面的代码不执行 3.存在浏览器兼容性,比如innerText在火狐浏览 ...
- 移动web前端下拉刷新效果
直接复制粘贴 放在页面中即可 <script> window.onload = function(){ window.addEventListener('touchstart', touc ...
- 两种让tableview返回顶部的方法
1. [self.tableView selectRowAtIndexPath:[NSIndexPath indexPathForRow:_currentRow inSection:0] animat ...
- Salesforce学习笔记(一)
Force平台简介 一.Force平台应用程序的优点1.以数据为中心的应用程序(一个对象就是一个数据库表) 由于该平台以数据库为中心,它让你能够编写以数据为中心的应用程序.以数据为中心的应用程序是基于 ...