ToB企服应用市场:ToB评测及商务社交产业平台

标题: Dapper.LiteSql 一款基于Dapper的ORM [打印本页]

作者: 九天猎人    时间: 2022-9-16 17:24
标题: Dapper.LiteSql 一款基于Dapper的ORM


写了这么久,代码没有越写越多,代码量的数量级没变,用SourceCounter代码统计工具统计了一下,一共4000多行代码。
ADO.NET换成Dapper后,我迷茫了,因为LiteSql做的工作变少了,它存在的意义就变小了,代码量也变少了。
Dapper支持所有ADO.NET支持的数据库,所以Dapper.LiteSql也可以很方便地支持更多数据库。
在Dapper的基础上,Dapper.LiteSql提供了哪些功能?

以上功能,不同数据库实现起来是有区别的,Dapper.LiteSql用最小的代价支持更多的数据库,只要ADO.NET支持的数据库,都可以很方便地通过实现IProvider接口支持(仅需写150行左右的代码)。
Dapper.LiteSql满足基本的增删改查是够用了,当初还是DBHelper时,我上家公司就用它来开发ERP、CRM等系统,是够用的;其它的Dapper兜底。
LiteSql和Dapper.LiteSql

基于ADO.NET无其它依赖的版本叫LiteSql,基于Dapper的版本叫Dapper.LiteSql,后面以Dapper.LiteSql为维护重点。
最近为了完善,做了一些破坏性的修改,好在没什么人用,没包袱;后续应该不会再变动接口,暂时也没有要添加的功能了。
插入、更新、删除功能说明

查询功能说明

典型的查询是通过拼SQL。
  1. int? status = 0;
  2. string remark = "测试";
  3. DateTime? startTime = null;
  4. DateTime? endTime = DateTime.Now;
  5. using (var session = LiteSqlFactory.GetSession())
  6. {
  7.     session.OnExecuting = (s, p) => Console.WriteLine(s);
  8.     ISqlString sql = session.CreateSql(@"
  9.         select t.*, u.real_name as OrderUserRealName
  10.         from bs_order t
  11.         left join sys_user u on t.order_userid=u.id
  12.         where 1=1")
  13.         .Append(" and t.status=@status", status);
  14.         .AppendIf(!string.IsNullOrWhiteSpace(remark), " and t.remark like @remark", "%" + remark + "%");
  15.         .AppendIf(startTime.HasValue, " and t.order_time >= @startTime ", startTime);
  16.         .AppendIf(endTime.HasValue, " and t.order_time <= @endTime", endTime);
  17.         .Append(" order by t.order_time desc, t.id asc ");
  18.     long total = sql.QueryCount();
  19.     List<BsOrder> list = sql.QueryPage<BsOrder>(null, pageModel.PageSize, pageModel.CurrentPage);
  20. }
复制代码
4. 关于原生SQL和Lambda表达式混写

建议以原生SQL为主,Lambda表达式辅助。
如果下一句是Lambda表达式写法,上一句是拼SQL写法,那么拼SQL写法Append要带泛型(也就是返回ISqlQueryable接口用于下一句写Lambda表达式);如果下一句是拼SQL写法,那么Append可带泛型也可不带,不带泛型就是返回ISqlString接口用于拼SQL。
混写比较灵活,需要花少量时间熟悉一下,SQL与Lambda拼接方式比较固定。Dapper.LiteSql在开发过程中,自然要尽量支持各种写法,但实际使用建议使用固定拼接模式。
没什么可讲的了,就这些功能。

附:拼SQL经典示例:
  1. t."captured_time" >= {StartTime:DateTime}
复制代码
后续

只要代码写的足够少,就...没有BUG?嗯...最新版本暂时没有发现BUG,因为除了我自己没什么人用。
使用的是Dapper的理念,不会像EFCore那样追求强大的功能,不会追求在Lambda表达式方面做到极致,暂不会添加新功能,暂时还不知道有没有必备功能还没有加。
NuGet地址:

https://www.nuget.org/packages/Dapper.LiteSql
Dapper.LiteSql源码地址:

https://gitee.com/s0611163/Dapper.LiteSql
配套实体类生成器地址:

https://gitee.com/s0611163/ModelGenerator
之前出现一个失误,代码注释里含有一个敏感信息,导致我把原来的仓库删了,建了个新的。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4