SqlHelper简单实现(通过Expression和反射)1.引言

之前老大说要改变代码中充斥着各种Select的Sql语句字符串的情况,让我尝试着做一个简单的SqlHelper,要具有以下功能:

1.不要在业务代码中暴露DataTable或者DataSet类型;

2.可以完成Select操作,需要支持条件查询,分页,单条记录查询,排序,连表,单个值;

3.可以完成添加单条记录,添加多条记录,修改记录和删除记录;

4.使用过程中要兼容老代码,既允许直接传入Sql;

5.要同时兼容MySql和Sql Server。

我之前写过很多Linq的代码,对那种函数式编程很是喜欢,所以考虑可否按照Lambda表达式来生成Sql。对于这部分的内容有很多,所以我单开一个系列来分享一下我的解决方案:

解决方案的结构如下:

 传送门:

SqlHelper简单实现(通过Expression和反射)1.引言

SqlHelper简单实现(通过Expression和反射)2.特性和实体设计

SqlHelper简单实现(通过Expression和反射)3.实体,数据传输对象(DTO)Helper类设计

SqlHelper简单实现(通过Expression和反射)4.对象反射Helper类

SqlHelper简单实现(通过Expression和反射)5.Lambda表达式解析类

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

SqlHelper简单实现(通过Expression和反射)7.MySql数据处理类

SqlHelper简单实现(通过Expression和反射)8.Sql Server数据处理类

SqlHelper简单实现(通过Expression和反射)9.Sql表述对象SqlSession

SqlHelper简单实现(通过Expression和反射)10.使用方式

原文地址:https://www.cnblogs.com/kakura/p/6108828.html