一步步学习NHibernate(2)——配置NHibernate的环境

请注明转载地址:http://www.cnblogs.com/arhat

第二章 环境搭建

在上一章中,我们知道了NHibernate是用来干什么的了,那么今天在本章中,我们开始搭建NHibernate的运行环境,在讲述NHibernate的时候,我们采用C#控制台应用程序来讲解,等到后面的时候,我们使用ASP.NET MVC和NHibernate的结合来开发项目。在以前,老魏写过一个《ASP.NET MVC NHibernate 整合》,这篇文章老魏写的有问题,有其事Nhibernate的GetCurrentSession的问题,那么老魏在讲解NHibernate的时候会专门来讲解这个只是,同时更改一下《ASP.NET MVC NHibernate 整合》的内容。

首先我们得进入到NHibernate的官方网站下载NHibernate的必要文件,地址:http://nhforge.org/大家可以自行下载。这里呢,老魏使用的是NHibernate-3.2.0,数据库使用的是MySQL。

首先我们建立一个空的解决方案“NHibernateStudy”,在解决方案中我们创建两个项目,一个是c#控制台应用程序NHibernateTest,另外一个是C#类库DAL。

wps_clip_image-20240

在NHibernateTest中,我们添加一个应用程序配置文件App.config。顺便添加NHibernateTest对DAL的应用。我们在DAL中添加NHibernate的两个必要dll文件“Iesi.Collections.dll”,“NHibernate.dll”文件,并生成以下解决方案。

更改App.config文件,内容如下:

<configSections>

<!--声明NHibernate的配置节点-->

        <section name="hibernate-configuration" type="NHibernate.Cfg.ConfigurationSectionHandler, NHibernate" />

    </configSections>

    <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">

<!--SessionFactory的配置-->

        <session-factory>

<!--方言用的是Mysql-->

            <property name="dialect">NHibernate.Dialect.MySQL5Dialect</property>

<!--是否显示sql语句-->

            <property name="show_sql">true</property>
<!--使用NHibernate提供的MySql驱动-->

            <property name="connection.driver_class">NHibernate.Driver.MySqlDataDriver</property>

<!--链接字符串-->

            <property name="connection.connection_string">persistsecurityinfo=True;server=127.0.0.1;user id=root;password=symjie;database=school</property>

          </session-factory>

    </hibernate-configuration>

其中在这个配置文件中出现了一个非常重要的SessionFactory的配置,这个配置对应着一个对象”SessionFactory”,这个对象是会话工厂,提供一个有效的会话链接。这一点在后面的代码中,老魏讲详细的说明。

然后我们在DAL项目中,创建一个NHibernateHelper.cs文件,内容如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using NHibernate.Cfg;

using NHibernate;

namespace DAL

{

public class NHibernateHelper

    {

//会话工厂

public static ISessionFactory factory = null;

static NHibernateHelper() 

        {

//读取配置文件,根据配置文件创建一个会话工厂,而这个就是从<session-factory>节点中读取的信息

            factory = new Configuration().Configure().BuildSessionFactory();

        }

//定义一个打开数据库链接的方法

public static ISession OpenSession()

        {

//通过工厂打开一个Session(会话)

return factory.OpenSession();

        }

    }

}

在这个类中,我们出现了两个接口,ISessionFactory和ISession,其中ISessionFactory是一个会话工厂,用于提供数据库链接会话的创建。ISession是表示一个数据库链接的会话,这里我们可以认为是一个数据库链接相当于ADO.NET 中的Connection,但是实际上ISession的功能比Connection要强大的多。

我们在DAL中,创建一个测试文件“Test.cs”内容如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using NHibernate;

namespace DAL

{

public class Test

    {

public void TestConnection() 

        {

ISession session = NHibernateHelper.OpenSession();

using (session)

            {

Console.WriteLine("是否已经打开数据库链接?" + session.IsOpen);

            }

Console.WriteLine("数据库是否已经关闭链接?" + session.IsOpen);

        }

    }

}

然后更改一下NHibernateTest项目中的Program.cs文件,在主函数中创建Test类,并调用Test类的TestConnection方法来测试一下数据库是否打开。

static void Main(string[] args)

        {

            DAL.Test test = new DAL.Test();

            test.TestConnection();

        }

运行一下程序,看看结果。

wps_clip_image-9060

看来,我们已经成功的配置了NHibernate的测试项目,并成功的打开数据库和关闭数据库了。

posted on 2014-02-24 21:06  大话济公  阅读(1225)  评论(6编辑  收藏  举报