以前只听说过NHibernate,没有在实际的开发中使用过,现在做项目要用到,又要耗费不少脑细胞了,痛苦。。。。
Nhibernate是基于ms.net的O/R Mapping持久框架,它从基于Java的Hibernate项目移植而来。O/R Mapping就是把对象到映射关系数据库的记录,简单的说就是能实现把一个对象存储为数据表中的一条记录和由一条记录创建一个相应的对象,数据表中的数据就是对象的属性。还好以前对java平台下的Hibernate有所了解。。ok,go go go:
新建一个web项目(NHibernateDemo),引用NHibernate.dll组件(先做个简单的),在Web.config中添加配置文件,指定所要连接的数据库:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

以上添加到<system.web>上面。
再新建一个类库项目(NHibernateDemoClass),用来配置业务数据域:
配置一个数据映射(新建一个xml文件:user.hbm.xml)


1

2

3

4

5

6

7

8

9

10

11

12

在解决方案资源管理器中,将该xml文件(user.hbm.xml)的属性生成操作修改为嵌入的资源(我可是没有看仔细,浪费了一个多小时的时间)。
创建一个.net的实体对应以上的xml文件(NDUser类)


1

2

3

4

5

6

7

8



9



10



11

12

13



14



15



16

17

18



19



20



21

22

23



24



25



26

27

28



29



30



31

通过以上的配置,现在在web项目中,进行对数据库的简单操作:
添加以下的引用:
using NHibernate;
using NHibernate.Cfg;
using NHibernateDemoClass;
using NHibernate.Expression;


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15



1

2

3

4

5

6

7

8

9

10



1

2

3

4

5

6

7

8

9

10

11

ok,以上只是简单的配置和操作而已。。接下来就研究多表关联了。。。