2.创建NHibernateHelper帮助类,生成sessionFactory

接上一篇文章 使用FluentNHibemate 操作数据库,添加映射到数据库

http://www.cnblogs.com/fzxiaoyi/p/8443586.html

Model文件下再创建个新的类NHibernateHelper

 

编写代码如下:

using NHibernate;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace MySQLDateBase.Model
{
    /// <summary>
    /// 这个帮助类是用来得到session,使用session来操作数据库
    /// </summary>
    class NHibernateHelper
    {
        //单例模式  sessionFactory可以取得session,利用session可以去操作数据库。
        private static ISessionFactory sessionFactory = null;
        private static string dateBase = "game"; //数据库名称
        private static string dateUserName = "root"; //数据库用户名
        private static string datePassWord = "root"; //数据库密码

        private static ISessionFactory SessionFactory
        {
            get
            {
                if (sessionFactory == null)
                    InitSessionFanctory();
                return sessionFactory;
            }
        }

        //初始化sessionFactory
        private static void InitSessionFanctory()
        {
            /*出现异常:
            “FluentNHibernate.Cfg.FluentConfigurationException”类型的未经处理的异常在 
            FluentNHibernate.dll 中发生

            解决方法:下载 mysql-connector-net-6.9.9.msi进行安装,使用MySql.Data.dll连接
            http://dev.mysql.com/downloads/connector/net/    
            */
            
            sessionFactory = FluentNHibernate.Cfg.Fluently.Configure().Database(FluentNHibernate.Cfg.Db.MySQLConfiguration.Standard.ConnectionString
         (db => db.Server("localhost").Database(dateBase).Username(dateUserName).Password(datePassWord))).Mappings(x => x.FluentMappings.AddFromAssemblyOf<NHibernateHelper>()).BuildSessionFactory();
        }
        //用于获取Session
        public static ISession OpenSession()
        {
            return SessionFactory.OpenSession();
        }
    }
}

  

posted @ 2018-02-12 05:27  SmallOverFllow  阅读(260)  评论(0编辑  收藏  举报