NHibernate实例
1. 下载相关资源:
- 下载NHibernate。下载地址: http://nhforge.org/Default.aspx

- 下载微软Northwind示例数据库,下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=23654
2. 下载NHibernate后解压缩文件,看到如下文档结构。本示例会用到Required_Bins目录下的文件。

- 下载微软Northwind,打开SQL Server 直接运行instnwnd.sql文件的脚本就可以了。
3. 打开Visual Studio 2008。新建NHibernate.Sample解决方案。

4. 在新建的解决方案下创建如下新项目:
- NHibernate.Sample.Business 【模板:类库】;处理业务逻辑
- NHibernate.Sample.Data 【模板:类库】;处理数据访问
- NHibernate.Sample.Lib 【模板:类库】;存放外部资源
- NHibernate.Sample.Model 【模板:类库】;处理业务模型
- NHibernate.Sample.Output 【模板:控制台应用程序】;测试输出
创建好以后,解决方案目录如下:

5. NHibernate.Sample.Lib项目,用来统一存放本示例用到的所有外部资源。创建三个个文件夹,分别为Dll、Schema、DBScript;分别用来存放NHibernate相关Dll文件、Schema文件和示例用到的数据库脚本文件。下面需要把相应的文件拷贝到对应的文件夹下。【这一步可以做,也可以不做。一般在真实的项目都会做,方便统一管理】。
完成的NHibernate.Sample.Lib项目结构如下:

instnwnd.sql文件来自下, 载微软Northwind示例数据库。第一步已经提供了下载地址。Iesi.Collections.dll、NHibernate.dll、nhibernate-configuration.xsd、nhibernate-mapping.xsd四个文件都来自下载的NHibernate,Required_Bins文件目录下。
6. NHibernate.Sample.Model项目,用来创建模型,对应于数据库中的表。添加Customer类,添加Mapping文件夹。
- 在Mapping文件夹下创建Customer.hbm.xml文件:

- 创建好Customer.hbm.xml文件以后,在打开的编辑界面内,右键=》属性。
- 打开属性管理窗口:

- 在属性管理窗口的架构一项,选择架构文件。架构文件的地址,就是我们上一步已经拷贝到NHibernate.Sample.Lib项目中的nhibernate-mapping.xsd文件。添加好以后编辑Customer.hbm.xml文件,就更够通过Visual Studio智能所用到的配置项。

- 在解决方案管理器中找到Customer.hbm.xml文件,右键=》属性

- 把“生成操作”属性改为:嵌入的资源。

- 完成Customer.hbm.xml文件内容:【注意:assembly和namespace属性】

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NHibernate.Sample.Model" namespace="NHibernate.Sample.Model">
<class name="Customer" table="Customers" lazy="true">
<id name="CustomerID" column="CustomerID" type="string"/>
<property name="CompanyName" type="string">
<column name="CompanyName" length=""/>
</property>
<property name="ContactName" type="string">
<column name="ContactName" length=""/>
</property>
<property name="ContactTitle" type="string">
<column name="ContactTitle" length=""/>
</property>
<property name="Address" type="string">
<column name="Address" length=""/>
</property>
<property name="City" type="string">
<column name="City" length=""/>
</property>
<property name="Region" type="string">
<column name="Region" length=""/>
</property>
<property name="PostalCode" type="string">
<column name="PostalCode" length=""/>
</property>
<property name="Country" type="string">
<column name="Country" length=""/>
</property>
<property name="Phone" type="string">
<column name="Phone" length=""/>
</property>
<property name="Fax" type="string">
<column name="Fax" length=""/>
</property>
</class>
</hibernate-mapping>

- 添加Customer.cs文件,完成Customer类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace NHibernate.Sample.Model
{
public class Customer
{
/// <summary>
///
/// </summary>
public virtual string CustomerID { get; set; } /// <summary>
///
/// </summary>
public virtual string CompanyName { get; set; } /// <summary>
///
/// </summary>
public virtual string ContactName { get; set; } /// <summary>
///
/// </summary>
public virtual string ContactTitle { get; set; } /// <summary>
///
/// </summary>
public virtual string Address { get; set; } /// <summary>
///
/// </summary>
public virtual string City { get; set; } /// <summary>
///
/// </summary>
public virtual string Region { get; set; } /// <summary>
///
/// </summary>
public virtual string PostalCode { get; set; } /// <summary>
///
/// </summary>
public virtual string Country { get; set; } /// <summary>
///
/// </summary>
public virtual string Phone { get; set; } /// <summary>
///
/// </summary>
public virtual string Fax { get; set; }
}
}

- 创建好以后NHibernate.Sample.Model项目的目录结构如下:

7. NHibernate.Sample.Data项目,用来数据访问。创建文件夹Config,用来存放配置文件,创建数据访问基类,创建数据访问接口,创建数据访问类。
- 创建NHiberane的配置文件hibernate.cfg.xml:

- 设定hibernate.cfg.xml文件的框架,在文件的编辑窗口右键=》属性=》添加=》选择Schema文件(NHibernate.Sample.Lib项目中的nhibernate-configuration.xsd文件)。

- 完成hibernate.cfg.xml文件的内容:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
<session-factory>
<property name="dialect">NHibernate.Dialect.MsSql2008Dialect</property>
<property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
<property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property>
<property name="connection.connection_string_name">Connection String</property>
<property name="connection.isolation">ReadCommitted</property>
<property name="show_sql">false</property>
<mapping assembly="NHibernate.Sample.Model"/>
</session-factory>
</hibernate-configuration>

- 添加BaseOperator.cs文件,完成BaseOperator类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using NHibernate;
using NHibernate.Cfg; namespace NHibernate.Sample.Data
{
public class BaseOperator
{
private ISession m_Session; public ISession Session
{
get { return m_Session;}
} private ISessionFactory m_SessionFactory; public BaseOperator()
{
var config = new Configuration().Configure("Config/hibernate.cfg.xml");
m_SessionFactory = config.BuildSessionFactory();
m_Session = m_SessionFactory.OpenSession();
}
}
}

- 添加CustomerOperator.cs文件,完成CustomerOperator类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using NHibernate.Linq;
using NHibernate.Sample.Model; namespace NHibernate.Sample.Data
{
public class CustomerOperator : BaseOperator
{ public object Save(Customer customer)
{
var id = Session.Save(customer);
Session.Flush();
return id;
} public void Update(Customer customer)
{
Session.Update(customer);
Session.Flush();
} public void Delete(Customer customer)
{
Session.Delete(customer);
Session.Flush();
} public Customer Get(object id)
{
return Session.Get<Customer>(id);
} public IList<Customer> GetAll()
{
return Session.Query<Customer>().ToList();
} }
}

- 完成后的NHibernate.Sample.Data目录结构如下:

8. NHibernate.Sample.Business项目用来,处理业务逻辑;本示例比较简单,我们只添加一个逻辑处理类CustomerLogic,内容如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using NHibernate.Sample.Data;
using NHibernate.Sample.Model; namespace NHibernate.Sample.Business
{
public class CustomerLogic
{
public IList<Customer> GetAll()
{
CustomerOperator oper = new CustomerOperator();
return oper.GetAll();
}
}
}

- 完成以后项目结构如下:

9. NHibernate.Sample.Output为控制台项目,用来测试输出。添加一个配置文件App.config用于连接数据库,内容视个人环境而定。
App.config内容如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<connectionStrings>
<add name="Connection String" connectionString="Data Source=.\SQLExpress;Initial Catalog=Northwind;Integrated Security=SSPI;" />
</connectionStrings>
</configuration>

- Program文件内容如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using NHibernate.Sample.Business;
using NHibernate.Sample.Model; namespace NHibernate.Sample.Output
{
class Program
{
static void Main(string[] args)
{
GetAll();
} private static void GetAll()
{
CustomerLogic logic = new CustomerLogic();
IList<Customer> cList = logic.GetAll(); foreach (Customer item in cList)
{
Console.WriteLine(item.CustomerID.ToString());
}
Console.Read();
}
}
}

- NHibernate.Sample.Output为控制台项目下,E:\Study\NHibernate.Sample\NHibernate.Sample.Output\bin\Debug应包含如下文件。否则无法运行成功;如果缺少去其他项目中拷贝一份过来就可以了。

10. 运行结果如下:

11. 【代码下载】
NHibernate实例的更多相关文章
- Nhibernate的第一个实例
第一个NhIbernate程序 1.目的: a) 链接到oracle数据库 b) 增删改 c) 基本查询.sql查询 d) 视图查询 e) 使用存储过程 f) 多表查询.级联查询 g) 级联增删改 2 ...
- NHibernate简单使用介绍
1.在数据库中新建表格,并插入记录,SQL如下: USE WFC_DB GO create table Students ( Id ,) not null, Name ), Age int, Scor ...
- NHibernate之旅系列文章导航
NHibernate之旅系列文章导航 宣传语 NHibernate.NHibernate教程.NHibernate入门.NHibernate下载.NHibernate教程中文版.NHibernate实 ...
- NHibernate 基础教程
NHibernate之旅系列文章导航 宣传语 NHibernate.NHibernate教程.NHibernate入门.NHibernate下载.NHibernate教程中文版.NHibernate实 ...
- NHibernate初学一之简单增删改查
以前有简单了解NHibernate,但因项目一直没有运用所以也没有机会进行一个详细了解:最近利用一点空闲的时间认真学习它:同样希望把学习过程进行简单记录,今天简单写一个针对MSSQL数据库的增删改查的 ...
- 最近学习工作流 推荐一个activiti 的教程文档
全文地址:http://www.mossle.com/docs/activiti/ Activiti 5.15 用户手册 Table of Contents 1. 简介 协议 下载 源码 必要的软件 ...
- 关于NHibernate中存在于Session中实例的3种状态的简单分析
在使用NHibernate的时候.在Session中会有3种状态. 1. 瞬时状态 (Transient) 由 new 命令开辟内存空间的对象,也就是平时所熟悉的普通对象. 如: Student st ...
- NHibernate初学三之条件查询(Criteria Queries)与AspNetPager分页实例
NHibernate除了SQL与HQL两种查询操作外,还有一种就是条件查询Criteria,本文将从网上整理一些Criteria的理论及小实例,最后通过一个结合AspNetPager分页来加深理解,必 ...
- NHibernate N+1问题实例分析和优化
1.问题的缘起 考察下面的类结构定义 public class Category { string _id; Category _parent; IList<Category> _chil ...
随机推荐
- Oracle PLSQL Demo - 10.For Loop遍历游标[FOR LOOP CURSOR]
declare cursor cur_emp is select t.* from scott.emp t; begin for r_emp in cur_emp loop dbms_output.p ...
- html+js+css+接口交互+echarts实例一枚
1. 解决了echarts的展现 2. 解决了echarts全屏幕展现(width:100%;height:100%;) 3. 解决了向接口取数据问题 <!DOCTYPE html> &l ...
- shell替换掉两个以上的空格
方法一:sed 's/ \+/ /g' test.txt > test1.txt
- Android开发日记(五)
从服务器端传递多个数据 先在服务器端设置cs文件 using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System; using Syst ...
- OAuth2.0流程图
OAuth2.0是用户验证和授权标准
- VC6.0启动File-open和Project-add file to project崩溃的解决方法
最近由于装了Office2010,VC6.0被整残了,file->open 和 Project->add file to project不能用,一用VC6.0就崩溃,查到是由于office ...
- C#基础-获得当前程序的 空间名.类名.方法名
string typeName = this.GetType().ToString();//空间名.类名 string typeName = this.GetType().Name;//类名 new ...
- Hibernate使用createSqlQuery进行模糊查询时找不到数据
1. 首先明确一点,使用createSqlQuery如下两种方式的占位符都可以使用,这个在官方的文档可以查到. 注意使用模糊查询时,赋值两边不可以添加单引号. Query query = sess.c ...
- 2012关闭ECN
Windows Server 2012 关闭TCP ECN (2014-03-20 18:22:42) 转载▼ 标签: it 分类: windows
- MongoDB(六):使用C#代码连接并读取MongoDB数据库
在上篇文章中,讲解了MongoDB的基本操作,包括增.删.改.查,但是这些操作都是在命令行模式下进行的,这篇文章中讲解如何使用C#程序连接到MongoDB数据库,并且读取里面的文档. 一.新建项目 新 ...