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 > ( null null , 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      }

 

你可能感兴趣的:(Hibernate)