zoukankan      html  css  js  c++  java
  • NHibernate封装代码

          NHibernate已经成为.net主流的ORM框架,当然,在开发中如果需要使用NHibernate的话,我们一般会对她进行一次封装,以便在项目中使用更方便,以及对NHibernate有一个全局的控制。而对NHibernate的封装也不是那么简单的,比如说NHibernate无法做到夸层的封装,意思就是在其他层使用封装的代码的时候,也是需要引用NHibernate的,比如一般的IQuery条件查询,如果需要排序或者动态条件的话,就需要传递ICriterion到调用层进行设置,当然如果是hql可以使用拼接的方法,但不推荐这种拼接的方法在UI层使用,这样跟sql没有什么差别。

    下面代码是我在学习的项目中使用的一点封装,当然没有经过严格的测试,如有bug请告知。

     首先是对NHibernate的SessionFactory的封装,这个就大同小异了

    View Code
     1 using System;
     2 using System.Collections.Generic;
     3 using System.Linq;
     4 using System.Text;
     5 using System.Web;
     6 using NHibernate;
     7 using NHibernate.Cfg;
     8 using System.Collections;
     9 
    10 namespace LBC.Permission.DAL
    11 {
    12 
    13     public class NHSessionFactory
    14     {
    15         private static readonly object lockObj = new object();
    16         private static NHSessionFactory instance = null;
    17         private static ISessionFactory factory;
    18 
    19         private NHSessionFactory() { }
    20 
    21         public static NHSessionFactory Instance
    22         {
    23             get
    24             {
    25                 if (instance == null)
    26                 {
    27                     lock (lockObj)
    28                     {
    29                         if (instance == null)
    30                         {
    31                             instance = new NHSessionFactory();
    32                             Configuration cfg = new Configuration();
    33                             factory = cfg.Configure().BuildSessionFactory();
    34                         }
    35                     }
    36                 }
    37                 return instance;
    38             }
    39         }
    40 
    41         public ISession GetCurrentSession()
    42         {
    43             return factory.GetCurrentSession();
    44         }
    45 
    46         public ISession OpenSession()
    47         {
    48             return factory.OpenSession();
    49         }
    50 
    51         public ISessionFactory SessionFactory
    52         {
    53             get
    54             {
    55                 return factory;
    56             }
    57         }
    58 
    59     }
    60 }

    然后是对常用方法的封装

    View Code
     1 public partial class DataAccess
     2     {
     3         private ISession session;
     4 
     5         public DataAccess()
     6         {
     7             session = NHSessionFactory.Instance.GetCurrentSession();
     8         }
     9 
    10         #region Transaction
    11 
    12         public void Transaction(Action action)
    13         {
    14             ITransaction transaction = session.BeginTransaction();
    15             try
    16             {
    17                 action();
    18                 transaction.Commit();
    19             }
    20             catch
    21             {
    22                 transaction.Rollback();
    23                 throw;
    24             }
    25         }
    26 
    27         public void Transaction(Action action, System.Data.IsolationLevel isolationLevel)
    28         {
    29             ITransaction transaction = session.BeginTransaction(isolationLevel);
    30             try
    31             {
    32                 action();
    33                 transaction.Commit();
    34             }
    35             catch
    36             {
    37                 transaction.Rollback();
    38                 throw;
    39             }
    40         }
    41 
    42         #endregion
    43     }

    基本的增删改操作

    View Code
      1 public partial class DataAccess
      2     {
      3         public T Get<T>(object id)
      4         {
      5             return session.Get<T>(id);
      6         }
      7 
      8         public T Load<T>(object id)
      9         {
     10             return session.Load<T>(id);
     11         }
     12 
     13         public void Insert(object obj)
     14         {
     15             session.Save(obj);
     16             session.Flush();
     17         }
     18 
     19         public void Update(object obj)
     20         {
     21             session.Update(obj);
     22             session.Flush();
     23         }
     24 
     25         public void InsertOrUpdate(object obj)
     26         {
     27             session.SaveOrUpdate(obj);
     28             session.Flush();
     29         }
     30 
     31         #region Delete
     32 
     33         /// <summary>
     34         /// 根据实体对象删除
     35         /// </summary>
     36         /// <param name="obj">实体对象</param>
     37         public void Delete(object obj)
     38         {
     39             session.Delete(obj);
     40             session.Flush();
     41         }
     42 
     43         /// <summary>
     44         /// 根据hql语句删除
     45         /// <example>
     46         /// hql="from 类名 where 属性名=值"
     47         /// </example>
     48         /// </summary>
     49         /// <param name="hql">hql语句</param>
     50         public void DeleteByQuery(string hql)
     51         {
     52             session.Delete(hql);
     53             session.Flush();
     54         }
     55 
     56         /// <summary>
     57         /// 根据Query进行删除
     58         /// <example>
     59         /// hql="delete from 类名 where 属性名=:参数名";
     60         /// </example>
     61         /// </summary>
     62         /// <param name="hql">hql语句</param>
     63         /// <param name="name">参数名称</param>
     64         /// <param name="value">参数值</param>
     65         public void DeleteByQuery(string hql, string name, object value)
     66         {
     67             DeleteByQuery(hql, new string[] { name }, new object[] { value });
     68         }
     69 
     70         /// <summary>
     71         /// 根据Query进行删除
     72         /// <example>
     73         /// hql="delete from 类名 where 属性名=:参数名";
     74         /// </example>
     75         /// </summary>
     76         /// <param name="hql">hql语句</param>
     77         /// <param name="names">参数名称数组</param>
     78         /// <param name="values">参数值数组</param>
     79         public void DeleteByQuery(string hql, string[] names, object[] values)
     80         {
     81             IQuery query = session.CreateQuery(hql);
     82             for (int i = 0; i < names.Length; i++)
     83             {
     84                 query.SetParameter(names[i], values[i]);
     85             }
     86             query.ExecuteUpdate();
     87             session.Flush();
     88         }
     89 
     90         /// <summary>
     91         /// 根据Query进行删除
     92         /// <example>
     93         /// hql="delete from 类名 where 属性名=? and 属性名=?";
     94         /// </example>
     95         /// </summary>
     96         /// <param name="hql">hql语句</param>
     97         /// <param name="values">参数值数组</param>
     98         public void DeleteByQuery(string hql, object[] values)
     99         {
    100             IQuery query = session.CreateQuery(hql);
    101             for (int i = 0; i < values.Length; i++)
    102             {
    103                 query.SetParameter(i, values[i]);
    104             }
    105             query.ExecuteUpdate();
    106             session.Flush();
    107         }
    108 
    109         #endregion
    110     }

    Count操作

    View Code
     1 public partial class DataAccess
     2     {
     3         #region Count
     4 
     5         public int Count<T>() where T : class
     6         {
     7             ICriteria criteria = session.CreateCriteria<T>();
     8             return Convert.ToInt32(criteria.SetProjection(Projections.RowCount()).UniqueResult());
     9         }
    10 
    11         public int Count<T>(ICriterion expression) where T : class
    12         {
    13             ICriteria criteria = session.CreateCriteria<T>();
    14             if (expression != null)
    15             {
    16                 criteria.Add(expression);
    17             }
    18             return Convert.ToInt32(criteria.SetProjection(Projections.RowCount()).UniqueResult());
    19         }
    20 
    21         #endregion
    22     }

     Scalar操作

    View Code
     1 public partial class DataAccess
     2     {
     3         #region Scalar
     4 
     5         public object Scalar(string hql)
     6         {
     7             return session.CreateQuery(hql).UniqueResult();
     8         }
     9 
    10         public object Scalar(string hql, params object[] values)
    11         {
    12             IQuery query = session.CreateQuery(hql);
    13             for (int i = 0; i < values.Length; i++)
    14             {
    15                 query.SetParameter(i, values[i]);
    16             }
    17             return query.UniqueResult();
    18         }
    19 
    20         public object Scalar(string hql, string name, object value)
    21         {
    22             return Scalar(hql, new string[] { name }, new object[] { value });
    23         }
    24 
    25         public object Scalar(string hql, string[] names, object[] values)
    26         {
    27             IQuery query = session.CreateQuery(hql);
    28             for (int i = 0; i < names.Length; i++)
    29             {
    30                 query.SetParameter(names[i], values[i]);
    31             }
    32             return query.UniqueResult();
    33         }
    34 
    35 
    36         public object Scalar(string hql, Action<IQuery> action)
    37         {
    38             IQuery query = session.CreateQuery(hql);
    39             action(query);
    40             return query.UniqueResult();
    41         }
    42 
    43         #endregion
    44     }

    ScalarBySQL操作

    View Code
     1 public partial class DataAccess
     2     {
     3         #region ScalarBySQL
     4 
     5         public object ScalarBySQL(string sql)
     6         {
     7             return session.CreateSQLQuery(sql).UniqueResult();
     8         }
     9 
    10         public object ScalarBySQL(string sql, params object[] values)
    11         {
    12             ISQLQuery query = session.CreateSQLQuery(sql);
    13             for (int i = 0; i < values.Length; i++)
    14             {
    15                 query.SetParameter(i, values[i]);
    16             }
    17             return query.UniqueResult();
    18         }
    19 
    20         public object ScalarBySQL(string sql, string name, object value)
    21         {
    22             return ScalarBySQL(sql, new string[] { name }, new object[] { value });
    23         }
    24 
    25         public object ScalarBySQL(string sql, string[] names, object[] values)
    26         {
    27             ISQLQuery query = session.CreateSQLQuery(sql);
    28             for (int i = 0; i < names.Length; i++)
    29             {
    30                 query.SetParameter(names[i], values[i]);
    31             }
    32             return query.UniqueResult();
    33         }
    34 
    35         public object ScalarBySQL(string sql, Action<ISQLQuery> action)
    36         {
    37             ISQLQuery query = session.CreateSQLQuery(sql);
    38             action(query);
    39             return query.UniqueResult();
    40         }
    41 
    42         #endregion
    43     }

    基本的Query操作

     

    View Code
     1 public partial class DataAccess
     2     {
     3         #region Query
     4 
     5         public IList<T> Query<T>() where T : class
     6         {
     7             return session.CreateCriteria<T>().List<T>();
     8         }
     9 
    10         public IList<T> Query<T>(Action<ICriteria> action) where T : class
    11         {
    12             ICriteria criteria = session.CreateCriteria<T>();
    13             action(criteria);
    14             return criteria.List<T>();
    15         }
    16 
    17         public IList<T> Query<T>(ICriterion expression) where T : class
    18         {
    19             return Query<T>(expression, null);
    20         }
    21 
    22         public IList<T> Query<T>(ICriterion expression, Action<ICriteria> action) where T : class
    23         {
    24             ICriteria criteria = session.CreateCriteria<T>();
    25             if (expression != null)
    26             {
    27                 criteria.Add(expression);
    28             }
    29             if (action != null)
    30             {
    31                 action(criteria);
    32             }
    33             return criteria.List<T>();
    34         }
    35 
    36         public IList<T> Query<T>(string hql)
    37         {
    38             return session.CreateQuery(hql).List<T>();
    39         }
    40 
    41         public IList<T> Query<T>(string hql, params object[] values)
    42         {
    43             IQuery query = session.CreateQuery(hql);
    44             for (int i = 0; i < values.Length; i++)
    45             {
    46                 query.SetParameter(i, values[i]);
    47             }
    48             return query.List<T>();
    49         }
    50 
    51         public IList<T> Query<T>(string hql, string name, object value)
    52         {
    53             return Query<T>(hql, new string[] { name }, new object[] { value });
    54         }
    55 
    56         public IList<T> Query<T>(string hql, string[] names, object[] values)
    57         {
    58             IQuery query = session.CreateQuery(hql);
    59             for (int i = 0; i < names.Length; i++)
    60             {
    61                 query.SetParameter(names[i], values[i]);
    62             }
    63             return query.List<T>();
    64         }
    65 
    66         public IList<T> Query<T>(string hql, Action<IQuery> action)
    67         {
    68             IQuery query = session.CreateQuery(hql);
    69             action(query);
    70             return query.List<T>();
    71         }
    72 
    73         #endregion
    74     }

     

    Page Query操作

     

    View Code
     1 public partial class DataAccess
     2     {
     3         #region Page Query
     4 
     5         public IList<T> Query<T>(int pageIndex, int pageSize, out int recordCount) where T : class
     6         {
     7             return Query<T>(nullnull, pageIndex, pageSize, out recordCount);
     8         }
     9 
    10         public IList<T> Query<T>(ICriterion expression, int pageIndex, int pageSize, out int recordCount) where T : class
    11         {
    12             return Query<T>(expression, null, pageIndex, pageSize, out recordCount);
    13         }
    14 
    15         public IList<T> Query<T>(ICriterion expression, Order[] order,
    16             int pageIndex, int pageSize, out int recordCount) where T : class
    17         {
    18             IList<T> list = new List<T>();
    19             recordCount = 0;
    20             ICriteria query = session.CreateCriteria<T>();
    21             if (expression != null)
    22             {
    23                 query.Add(expression);
    24             }
    25             ICriteria queryPage = CriteriaTransformer.Clone(query);
    26             //获取记录总数
    27             recordCount = Convert.ToInt32(query.SetProjection(Projections.RowCount()).UniqueResult());
    28 
    29             //设置排序
    30             if (order != null)
    31             {
    32                 foreach (Order o in order)
    33                 {
    34                     queryPage.AddOrder(o);
    35                 }
    36             }
    37             queryPage.SetFirstResult((pageIndex - 1* pageSize);
    38             queryPage.SetMaxResults(pageSize);
    39             list = queryPage.List<T>();
    40 
    41             return list;
    42         }
    43 
    44         public IList<T> Query<T>(string hql, object[] values, int pageIndex, int pageSize)
    45         {
    46             IQuery query = session.CreateQuery(hql);
    47             for (int i = 0; i < values.Length; i++)
    48             {
    49                 query.SetParameter(i, values[i]);
    50             }
    51             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List<T>();
    52         }
    53 
    54         public IList<T> Query<T>(string hql, string name, object value, int pageIndex, int pageSize)
    55         {
    56             return Query<T>(hql, new string[] { name }, new object[] { value }, pageIndex, pageSize);
    57         }
    58 
    59         public IList<T> Query<T>(string hql, string[] names, object[] values, int pageIndex, int pageSize)
    60         {
    61             IQuery query = session.CreateQuery(hql);
    62             for (int i = 0; i < names.Length; i++)
    63             {
    64                 query.SetParameter(names[i], values[i]);
    65             }
    66             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List<T>();
    67         }
    68 
    69         public IList<T> Query<T>(string hql, int pageIndex, int pageSize)
    70         {
    71             IQuery query = session.CreateQuery(hql);
    72             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List<T>();
    73         }
    74 
    75         #endregion
    76     }

     

    SQL Query操作

    View Code
     1 public partial class DataAccess
     2     {
     3         #region SQL Query
     4 
     5         public IList QueryBySQL(string sql)
     6         {
     7             return session.CreateSQLQuery(sql).List();
     8         }
     9 
    10         public IList QueryBySQL(string sql, params object[] values)
    11         {
    12             ISQLQuery query = session.CreateSQLQuery(sql);
    13             for (int i = 0; i < values.Length; i++)
    14             {
    15                 query.SetParameter(i, values[i]);
    16             }
    17             return query.List();
    18         }
    19 
    20         public IList QueryBySQL(string sql, string name, object[] value)
    21         {
    22             return QueryBySQL(sql, new string[] { name }, new object[] { value });
    23         }
    24 
    25         public IList QueryBySQL(string sql, string[] names, object[] values)
    26         {
    27             ISQLQuery query = session.CreateSQLQuery(sql);
    28             for (int i = 0; i < names.Length; i++)
    29             {
    30                 query.SetParameter(names[i], values[i]);
    31             }
    32             return query.List();
    33         }
    34 
    35         public IList QueryBySQL(string sql, Action<ISQLQuery> action)
    36         {
    37             ISQLQuery query = session.CreateSQLQuery(sql);
    38             action(query);
    39             return query.List();
    40         }
    41 
    42         #endregion
    43     }

     

    Page SQL Query操作

     

    View Code
     1 public partial class DataAccess
     2     {
     3         #region Page SQL Query
     4 
     5         public IList QueryBySQL(string sql, object[] values, int pageIndex, int pageSize)
     6         {
     7             ISQLQuery query = session.CreateSQLQuery(sql);
     8             for (int i = 0; i < values.Length; i++)
     9             {
    10                 query.SetParameter(i, values[i]);
    11             }
    12             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List();
    13         }
    14 
    15         public IList QueryBySQL(string sql, string name, object value, int pageIndex, int pageSize)
    16         {
    17             return QueryBySQL(sql, new string[] { name }, new object[] { value }, pageIndex, pageSize);
    18         }
    19 
    20         public IList QueryBySQL(string sql, string[] names, object[] values, int pageIndex, int pageSize)
    21         {
    22             ISQLQuery query = session.CreateSQLQuery(sql);
    23             for (int i = 0; i < names.Length; i++)
    24             {
    25                 query.SetParameter(names[i], values[i]);
    26             }
    27             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List();
    28         }
    29 
    30         public IList QueryBySQL(string sql, int pageIndex, int pageSize)
    31         {
    32             ISQLQuery query = session.CreateSQLQuery(sql);
    33             return query.SetFirstResult((pageIndex - 1* pageSize).SetMaxResults(pageSize).List();
    34         }
    35 
    36         #endregion
    37     }

     

  • 相关阅读:
    Silverlight 置于悬浮层之下 背景透明的方法
    做流媒体服务器需要什么(FMS)
    Silverlight WebClient 上传实现
    Silverlight WCF 初尝小结
    自动判断页面上的图片是否加载成功,不成功替换为默认图片
    HTTP PUSH技术原理,结合ASP.NET实现以及评述
    AJAX 请求队列实现
    关于COOKIES需要注意的一点
    Silverlight WCF 上传实现
    Silverlight 上传 大文件分块上传
  • 原文地址:https://www.cnblogs.com/liubiaocai/p/2179350.html
Copyright © 2011-2022 走看看