SqlHelper简单实现(通过Expression和反射)6.Providor模式(工厂+策略)可配置数据库选择...

基本思想,将MsSqlDbUtility和MySqlDbUtility设计成单例模式,通过App.config或Web.config进行默认的数据库设置,然后通过DbUtilityFactory获取DbUtility。

1.接口:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Data;
  4 using System.Linq.Expressions;
  5 using RA.DataAccess.MsSqlDbUtility;
  6 
  7 namespace RA.DataAccess
  8 {
  9     public interface IDbUtility
 10     {
 11         /// 
 12         /// 获取Sql描述对象
 13         /// 
 14         /// 
 15         /// 
 16         SqlSession GetSqlExpression() where T : class;
 17         /// 
 18         /// 获取多条数据
 19         /// 
 20         /// 
 21         /// 
 22         /// 
 23         List GetList(SqlSession exp) where T : class;
 24         /// 
 25         /// 获取多条数据,并填入DTO中
 26         /// 
 27         /// 
 28         /// 
 29         /// 
 30         /// 
 31         List GetList(SqlSession exp) where T : class where Target : class;
 32         /// 
 33         /// 分页
 34         /// 
 35         /// 
 36         /// OrderBy表达式
 37         /// 
 38         /// 
 39         /// 
 40         List Paged(Expressionobject>> By, int pageIndex, int pageSize = 1) where T : class;
 41         /// 
 42         /// 获取单条数据
 43         /// 
 44         /// 
 45         /// linq表达式,代表条件
 46         /// 
 47         T GetSingle(Expressionbool>> func) where T : class;
 48         /// 
 49         /// 删除一条数据
 50         /// 
 51         /// 
 52         /// linq表达式,代表条件
 53         /// 
 54         int Delete(Expressionbool>> func) where T : class;
 55         /// 
 56         /// 添加一条数据
 57         /// 
 58         /// 
 59         /// 
 60         /// 
 61         int Add(T obj) where T : class;
 62         /// 
 63         /// 直接执行Sql
 64         /// 
 65         /// 
 66         /// 
 67         /// 
 68         int RunSingleSql(string sql) where T : class;
 69         /// 
 70         /// 通过Sql获取DataTable,业务层不使用
 71         /// 
 72         /// 
 73         /// 
 74         /// 
 75         DataTable GetDataBySql(string sql) where T : class;
 76         /// 
 77         /// 更新一条数据
 78         /// 
 79         /// 数据表实体
 80         /// 实体对象
 81         /// linq表达式,代表条件
 82         /// 
 83         int Update(T obj, Expressionbool>> func) where T : class;
 84         /// 
 85         /// 添加多条数据
 86         /// 
 87         /// 
 88         /// 实体对象列表
 89         /// 
 90         int AddList(List objs) where T : class;
 91         /// 
 92         /// 计数
 93         /// 
 94         /// 
 95         /// linq表达式,代表条件
 96         /// 
 97         int Count(Expressionbool>> func = null) where T : class;
 98         /// 
 99         /// 获取一个字段数据
100         /// 
101         /// 
102         /// 
103         /// linq表达式,代表字段
104         /// linq表达式,代表条件
105         /// 
106         Target Scala(Expression> field, Expressionbool>> func);
107     }
108 }

2.工厂类:

 1 using System;
 2 using System.Configuration;
 3 
 4 namespace RA.DataAccess
 5 {
 6     public class DbUtilityFactory
 7     {
 8         public static IDbUtility GetDbUtility()
 9         {
10             var getDbType = ConfigurationManager.AppSettings["DbType"];
11             if (getDbType == "MySql")
12             {
13                 return MySqlDbUtility.DbUtility.GetInstance();
14             }
15             else if (getDbType == "MsSql")
16             {
17                 return MsSqlDbUtility.DbUtility.GetInstance();
18             }
19             else
20             {
21                 throw new NotSupportedException("不支持的数据库");
22             }
23         }
24     }
25 
26 
27 }

 

转载于:https://www.cnblogs.com/kakura/p/6108987.html

你可能感兴趣的:(SqlHelper简单实现(通过Expression和反射)6.Providor模式(工厂+策略)可配置数据库选择...)