大家一起来学 NHibernate+NUnit (VS2012+SQL Server2008)

分类: C#2013-08-10 18:47 1589人阅读 评论(5) 收藏 举报

NHibernateNUnitVisual Studio 2012

如果你没听过Nhibernate or NUnit,那么,恭喜你,和我一样,握个手吧。如果你已经是个老酱油了,那就道不同不带你玩了,请自觉绕行,,,。谨以此文献给像我这样广大的小白同胞们(鼓掌)!

话说2013年某月某日,听一武林前辈提起 NHibernate ,小白我顿时大脑空白,这是个啥么东东啊,在强烈好奇心的驱使下,我决定先去吃晚饭,回来后便将此事忘掉了,。。。在此我只想说一句:我不是故意的!前几日,又偶闻坊间传言,话说欧特曼打小怪兽时,所使用的招式中就有NHibernate ANDNUnit,这下小白我可长记性了,为啥妮?因为像我这样广大小白的终极愿望就是穷极毕生之所学,打倒人世间一切妖魔鬼怪啊。话不多说,立马招来谷歌度娘拷打一番,根据“坦白从宽、抗拒从严”的原则,这俩小子把NHibernate和Nunit的勾当一五一十的全都招了出来,我心甚慰啊……原来NHibernate起源于java学派久负盛名的三大框架SSH之一:Hibernate。好吧,如果你和我一样,对java学派嗤之以鼻的话,那我就再废话一些:首先,你要明白,NHibernate在.NET中的作用和Hibernate在JAVA中的作用一样;第二,他们都是开源的东东;第三,他们都是一种对象关系数据库映射框架。第三点要好好理解哦,“对象”,.NET和java都是面向对象的,通俗点就是里面都是各种class类;“关系数据库”,MS SQL,ORACLE,etc,就是指的它们了;“映射“,就是在指hibernate在关系数据库和我们面向对象class之间搭起了一座桥梁。因此,有了这个,我们就可以轻松的使用面向对象的思维来编写数据层了,至于数据层如何与数据库打交道,就交给hibernate去处理了。那么NUnit 呢?这个简单,说白了,就一个测试工具,我们在里面写好测试代码,程序自动帮我们做测试,吼吼。说了那么多,其实,我也搞不明白,你们到底懂没懂……,至此,如果广大同胞们脑海中还是没有一丝波澜的话,那就请各位自己去拷打一番谷歌度娘吧。

由于NHibernate和NUnit 的东西实在太多,而小白我功力有限,所以,给大家推荐两个很好的博客,里面写的都很详细了:

1,NHibernate之旅系列文章导航 http://www.cnblogs.com/lyj/archive/2008/10/30/1323099.html

2,NHibernate从入门到精通系列http://www.cnblogs.com/GoodHelper/archive/2011/02/14/nhiberante_01.html

这两个博客里有些内容重叠了,但我还是建议大家都从头到尾好好读一下,毕竟我们是小白嘛,

不过两个博客千好万好,只有一点不好,就是年代久远,里面的示例很多地方语法都改变了,这下可把我这小伙伴给惊呆了,。还好小白我心里素质好,经过一番冥思苦想,总算一切搞定,下周二就七夕了,我也没啥好送的,就带大家一起来做一个NHibernate+NUnit的Demo吧,

开发环境:VS 2012 ,SQL Server 2008,NHibernate 3.3.3 ,NUnit 2.6.2

NHibernate 下载地址:NHibernate Forge

NUnit 下载地址:NUnit

当然了,稍后我会把Demo+NHibernate3.3.3+NUnit 2.6.2 一起打包,大家可以直接去下载。

Demo 下载地址:Demo

下面就正式开始了:

1,打开VS2012,新建项目,选择类库,起名为:Domain。确定

2,把自带的Class1.cs删掉,新建一个Student类。代码如下:

[csharp] view plaincopyprint?

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6. namespace Domain  
  7. {  
  8. /// <summary>
  9. /// 学生类
  10. /// </summary>
  11. public class Student  
  12. {  
  13. /// <summary>
  14. /// ID
  15. /// </summary>
  16. public virtual int ID { get; set; }  
  17. /// <summary>
  18. /// 学生姓名
  19. /// </summary>
  20. public virtual string Name { get; set; }  
  21. /// <summary>
  22. /// 学生性别
  23. /// </summary>
  24. public virtual string Sex { get; set; }  
  25. /// <summary>
  26. /// 学生年龄
  27. /// </summary>
  28. public virtual int Age { get; set; }  
  29. }  
  30. }

3,添加一个XML文件,取名为:Student.hbm.xml,如图:

此时,目录结构是这样的:

4,编写Student.hbm.xml 映射文件,代码如下:

[html] view plaincopyprint?

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Domain" namespace="Domain">
  3. <class name="Student" table="T_Student" lazy="true">
  4. <id name="ID" column="ID" unsaved-value="0">
  5. <generator class="native"></generator>
  6. </id>
  7. <property name="Name" type="string" column="StuName" length="20" not-null="true"></property>
  8. <property name="Sex" type="string" column="StuSex" length="2"></property>
  9. <property name="Age" type="Int32" column="StuAge"></property>
  10. </class>
  11. </hibernate-mapping>

XML 映射文件的编写是NHibernate中关键的一步,如果你没有预读那两篇博客的话,估计这里就看不懂了。注意:编写XML文件之前,记得把下载的NHibernate中的nhibernate-mapping.xsd文件和nhibernate-configuration.xsd文件放到C:\Program Files (x86)\Microsoft Visual Studio 11.0\Xml\Schemas目录下(我的是win7 64, 因机器不一,如果不知道放哪的话,就百度下吧),这样,编写xml文件时,VS就会有智能提示了。
5,在Student.hbm.xml 文件上右击,选择”属性“,将xml文件的生成操作属性由”内容“改为”嵌入的资源“。如下图:

6,在项目解决方案上右击,选择添加新建项目,添加一个新的类库,取名为:NHibernateTest。(其实,这就是我们利用UNit 进行单元测试的地方)如图:

将新建类库中默认的Class1.cs删掉,此时,目录结构是这样的:

7,在NHibernateTest 项目中,添加对我们刚才新建的Domain类库的引用,以及添加我们下载的NHibernate和NUnit 程序集的引用。如图:

引用添加完毕后,就是下面这个样子的,

10,把下载的NHibernate 中Configuration_Templates文件夹下的MSSQL.cfg.xml文件复制粘贴到NHibernateTest 类库中,并重命名为:hibernate.cfg.xml 并修改文件如下:

[html] view plaincopyprint?

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!--   
  3. This template was written to work with NHibernate.Test.  
  4. Copy the template to your NHibernate.Test project folder and rename it in hibernate.cfg.xml and change it   
  5. for your own use before compile tests in VisualStudio.  
  6. -->
  7. <!-- This is the System.Data.dll provider for SQL Server -->
  8. <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2" >
  9. <session-factory name="NHibernate.Test">
  10. <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property>
  11. <property name="connection.connection_string">
  12. Server=(local);initial catalog=nhibernate;Integrated Security=SSPI
  13. </property>
  14. <property name="dialect">NHibernate.Dialect.MsSql2008Dialect</property>
  15. <!--添加下面这行代码,除此之外,其它都不用改动,当然,你也可以修改上面的数据库链接字符串-->
  16. <mapping assembly="Domain"/>
  17. </session-factory>
  18. </hibernate-configuration>

然后,在hibernate.cfg.xml文件上右击,选择属性,将xml文件的复制到输入目录属性修改为:始终复制

11,添加NHibernateTest.cs类,代码如下:

[csharp] view plaincopyprint?

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6. using NHibernate;  
  7. using NHibernate.Tool.hbm2ddl;  
  8. using NUnit.Framework;  
  9. namespace NHibernateTest  
  10. {  
  11. [TestFixture]  
  12. public class NHibernateInit  
  13. {  
  14. [Test]  
  15. public void InitTest()  
  16. {  
  17. var cfg = new NHibernate.Cfg.Configuration().Configure(System.AppDomain.CurrentDomain.BaseDirectory + "\\hibernate.cfg.xml");  
  18. new SchemaExport(cfg).Execute(true, true, false);  
  19. using (ISessionFactory sessionFactory = cfg.BuildSessionFactory()) { }  
  20. }  
  21. }  
  22. }

12,打开SQL Server 08,新建一个nhibernate 数据库 

[sql] view plaincopyprint?

  1. create database nhibernate

13,在 NHibernateTest 类库上右键,选择属性,切换到”调试“选项卡,单击”启动外部调试“,浏览,选择Nunit.exe 程序。(注意:前提是你已经安装了文章开头时让你下载的Nunit 2.6.2.msi程序),效果如下图所示:


14,点击一下”全部保存“,然后在整个的项目解决方案上右键,选择”生成解决方案“。然后,将NHibernateTest 类库右键,设为启动项目。F5,运行程序

此时,我们看到NUnit.exe已经启动了,在NUnit窗口中,选择:"File"->”new project“,文件名为:NHibernateTest.nunit,点击保存。此时,窗口依然什么都没有。再选择:"Project"->"Add assembly",在弹出的对话框中,找到我们的NHibernateTest类库生成的dll文件,点击打开,如下图:

15,单击NUnit窗口中的Run按钮,此时,NUnit 会自动执行我们的NHibernateTest 类库中的方法。这时,窗口应该是下面这样的:

16,此时,打开数据库,会发现,我们的T_Student数据表已经被自动创建好了。

小伙伴们,你们有没有被惊呆呢?是不是很神奇的东东?哈哈……我发现写文章真是个体力活,受不了了……

唉,没办法,本着对广大的小伙伴尽职尽责的高度使命感,小白我决定继续码字……(鼓掌)

这样测试的话,每次我们都还要启动外部程序NUnit,相信有的小伙伴不乐意了,放心好了,我们可以通过安装插件的方式,解决这个问题(注意:此过程需联网)。

在 VS2012 中,选择:”工具“=》”扩展和更新“,在弹出的对话框中,单击”联机“标签,之后再在搜索框中输入:”NUnit“ ,回车,效果如下图所示:

选择”下载“,下载完毕后,会提示你安装,你直接选择安装就可以了。安装完毕后,重启一下VS。重启之后,选择菜单栏中的:”测试“-》”窗口“-》”测试资源管理器“。然后再重新生成一下整个项目解决方案,这时候,我们在”测试资源管理器“中就可以看到我们的NHibernateTest 测试类了。在这里,我们可以选择全部运行,也可以在单独的方法上右键,选择运行或调试。

下面,我又新写了几个测试方法,分别测试往T_Student表中存入数据,取出数据。NHibernateInit.cs 文件代码如下:

[csharp] view plaincopyprint?

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6. using NHibernate;  
  7. using NHibernate.Tool.hbm2ddl;  
  8. using NUnit.Framework;  
  9. namespace NHibernateTest  
  10. {  
  11. [TestFixture]//定义一个测试类,里面可以包含很多测试函数和初始化、销毁函数。
  12. public class NHibernateInit  
  13. {  
  14. [Test]//定义一个独立的测试函数。
  15. public void InitTest()  
  16. {  
  17. var cfg = new NHibernate.Cfg.Configuration().Configure(System.AppDomain.CurrentDomain.BaseDirectory + "\\hibernate.cfg.xml");  
  18. new SchemaExport(cfg).Execute(true, true, false);  
  19. using (ISessionFactory sessionFactory = cfg.BuildSessionFactory()) { }  
  20. }  
  21. private ISessionFactory _sessionFactory;  
  22. [SetUp]//定义测试函数初始化函数,每个测试函数运行前都会被调用一次。
  23. public void InitSessionFactory()  
  24. {  
  25. var cfg = new NHibernate.Cfg.Configuration().Configure(System.AppDomain.CurrentDomain.BaseDirectory + "\\hibernate.cfg.xml");  
  26. _sessionFactory = cfg.BuildSessionFactory();  
  27. }  
  28. [Test]  
  29. public void SaveTest()  
  30. {  
  31. var stu = new Domain.Student()  
  32. {  
  33. Name = "张三",  
  34. Sex = "M",  
  35. Age = 20  
  36. };  
  37. using (ISession session = _sessionFactory.OpenSession())  
  38. {  
  39. try
  40. {  
  41. object obj = session.Save(stu);  
  42. session.Flush();  
  43. Assert.NotNull(obj);  
  44. }  
  45. catch (Exception ex)  
  46. {  
  47. throw ex;  
  48. }  
  49. }  
  50. }  
  51. [Test]  
  52. public void SelectTest()  
  53. {  
  54. using (ISession session = _sessionFactory.OpenSession())  
  55. {  
  56. Domain.Student stu = session.Get<Domain.Student>(1);  
  57. Assert.NotNull(stu);  
  58. Console.WriteLine(stu.Name);  
  59. }  
  60. }  
  61. }  
  62. }

测试结果如下图所示:

OK了,到此为止,算是把NHibernate+NUnit 的demo完整演示一遍了,不知道各位小伙伴们看懂了没?末尾了,免不得再唠叨一句:珍爱生命,远离IT。。。。

注:关于使用NUnit 测试和 MS 测试框架之间的区别,大家可以去看我转载的一篇文章:Nunit Test 和 MS Test 的区别

大家一起来学 NHibernate+NUnit (VS2012+SQL Server2008)的更多相关文章

  1. NHibernate+NUnit (VS2012+SQL Server2008) (转)

    源博客:http://blog.csdn.net/jiajiayouba/article/details/9877875 首先,你要明白,NHibernate在.NET中的作用和Hibernate在J ...

  2. 用LinqPad查看Nhibernate生成的sql语句

    使用Nhibernate开发一般都要对Nhibernate生成的sql语句进行查看及分析,查看Nhibernate生成的sql语句,可以使用NHProfiler和log4net.但NHProfiler ...

  3. nhibernate中执行SQL语句

    在有些时候,可能需要直接执行SQL语句.存储过程等,但nhibernate并没有提供一种让我们执行SQL语句的方法,不过可以通过一些间接的方法来实现. 下面给出一个在nhibernate中执行SQL语 ...

  4. NHibernate直接执行SQL进行插入

    有时候,需要用NHibernate直接执行SQL进行数据insert或update. 怎么写呢?简单一点的,可以直接拼凑出来的SQL,这样写: using NHibernate; StringBuil ...

  5. SQL Server2008附加数据库失败

    今天旁晚时分,我准备把老师在上课时候发给我们的一个数据库附加到我的SQL Server2008上面去,本来在学校机房用的SQL Server2000是很顺利地就成功了,但是把*.mdf文件附加到我的0 ...

  6. sql server2008配置管理工具服务显示远程过程调用失败

    SQL SERVER2008配置管理工具服务显示远程过程调用失败   前两天,装了VS2012后,打开SQL2008配置管理工具,发现SQL服务名称里什么也没有,只有一个提示:(如图) 上网搜了,试了 ...

  7. 记录SQL Server2008日志文件损坏的恢复过程

    记录SQL Server2008日志文件损坏的恢复过程: 环境: 系 统:Windows Server2003 数据库:SQL Server2008 故障原因: 通过mstsc链接同一服务器时,用户界 ...

  8. SQL Server2008附加数据库之后显示为只读时解决方法

    啰嗦的话就不多说了,直入主题吧! 方案一: 碰到这中情况一般是使用的sa账户登录的,只要改为Windows身份验证,再附加数据库即可搞定. 方案二: 使用sa登录SQL Server2008附加数据库 ...

  9. win8安装SQL Server2008企业版

    win8 系统,安装的时候要先安装SQL Server2008企业版 再安装Visual studio2010,不然SQL Server会有问题.

随机推荐

  1. linux split

    说来惭愧,用了这么久linux会的命令也只有常用的那么几个.. 今天刚刚学到的一个很实用的split命令,原本就只是知道开发语言中有split方法用来切分字符串,linux命令行也提供了这样一个方法. ...

  2. C++ STL标准模板库(queue)

    //queue的使用 #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<queue> using name ...

  3. Windwos下连远程linux Hbase小问题

    前几天,兴起想仔细玩玩hbase,细细去研究一下,写了个小demo,从win7去连接另一台T510的ubuntu上的hbase.很简单的crud的操作程序,没有看出来什么问题,但是跑起来,硬是好像bl ...

  4. 日期类Date

    Java在日期类中封装了有关日期和时间的信息,用户可以通过调用相应的方法来获取系统时间或设置日期和时间.Date类中有很多方法在JDK1.0公布后已经过时了,在8.3中我们将介绍JDK1.0中新加的用 ...

  5. JavaWeb——过滤器

    过滤器简介 WEB过滤器是一个服务器端的组件,它可以截取用户端的请求与相应信息,并对这些信息过滤. 过滤器的工作原理和生命周期 在没有Web过滤器的情况下,用户直接访问服务器上的Web资源.但是如果存 ...

  6. bootstrap基础学习九篇

    现在学学bootstrap响应式实用工具 Bootstrap 提供了一些辅助类,以便更快地实现对移动设备友好的开发.这些可以通过媒体查询结合大型.小型和中型设备,实现内容对设备的显示和隐藏. 需要谨慎 ...

  7. 解决 Ubuntu 13.04 无法调节屏幕亮度的问题

    13.04与12.04大部分步骤是相同的,只是12.04的方法在13.04中失败了,所以还是有必要说明一下.我到电脑是宏碁AS4750G,硬盘安装系统后电源亮度无法调节. 解决方法如下: 终端输入代码 ...

  8. py-faster-rcnn 训练自己的数据

    转载:http://blog.csdn.net/sinat_30071459/article/details/51332084  Faster-RCNN+ZF用自己的数据集训练模型(Python版本) ...

  9. CornerStone配置SVN,HTTP及SVN简单使用说明

    本文转载至 http://blog.csdn.net/allison162004/article/details/38796857 已经安装了的小伙伴请直接看三步骤 一.下载地址 CornerSton ...

  10. ryu启动问题总结

    在Mininet中启动ryu控制器,首先切换到ryu中的app目录下: cd ryu/ryu/app 启动ryu: ryu-manager simple_switch.py 遇到了如下的错误提示: 这 ...