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();
        }
    }
}

  

转载于:https://www.cnblogs.com/fzxiaoyi/p/8443587.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值