ShadowSql之精简版拆分

ShadowSql拆分为精简版和易用版,项目和nuget包同步拆分

ShadowSql项目拆分为ShadowSql.Core和ShadowSql

Dapper.Shadow项目拆分为Dapper.Shadow.Core和Dapper.Shadow

Dapper.Shadow.Core依赖ShadowSql.Core

Dapper.Shadow依赖ShadowSql

精简版的目标是够用、直接,基于接口编程

易用版的目标是好用、易用,基于泛型编程

易用版依赖精简版,是在精简版上扩展而来

下面举几个例子对比一下

一、读取一张表的例子

  1. 精简版代码如下:
复制代码
        var table = SimpleDB.From("Students");        
        var count = table.Count(Executor);
        var select = new TableSelect(table);
        var students = select.Get<Student>(Executor);

2.易用版代码如下:

复制代码
        var select = Executor.From("Students")
            .ToDapperSelect();
        var count = select.Count();
        var students = select.Get<Student>();

在《ShadowSql之借Dapper打造高性能ORM及百变魔法》中有介绍Dapper执行的3种方式

精简版只支持其中1种,易用版3种都支持

二、分页查询数据的例子

  1. 精简版代码如下:
复制代码
        var table = new StudentTable("Students");
        var query = new TableSqlQuery(table)
            .Where(table.Age.GreaterEqualValue(9));
        var count = query.Count(Executor);
        var cursor = new TableCursor(query)
            .Desc(table.Id)
            .Skip(1)
            .Take(10);
        var select = new TableSelect(cursor);
        var students = select.Get<Student>(Executor);

2.易用版代码如下:

复制代码
        var query = new StudentTable("Students")
            .ToSqlQuery()
            .Where(table => table.Age.GreaterEqualValue(9));
        var count = query.Count(Executor);
        var students = query.ToCursor()
            .Desc(table => table.Id)
            .Skip(1)
            .Take(10)
            .ToSelect()
            .Get<Student>(Executor);

分页查询例子中两者的区别更明显,在易用版中如果不求count,整个过程可以全部连写,非常连贯

精简版基本每个组件要定义一个变量

易用版除了通过导航属性(扩展方法)串连各个组件外,还提供高阶函数(函数类型参数供主函数内调用)来进行个性化的查询

当然,易用版用到泛型会多出一丁点的cpu和内存开销,这些可以忽略不计的

另外这个例子也体现了本工具和SqlKata的设计思路的重大区别

SqlKata的Query是个大对象,把所有可能用到的组件都包含在内;

ShadowSql是按需分配,只有需要的时候才链接上需要的组件

这也是SqlKata比ShadowSql执行更慢,内存消耗更多的原因之一

精简版和易用版各有优缺点,萝卜白菜各有所爱,两种我都喜欢的。

如果写小工具,就偏爱易用版。如果做微服务精简版很适合。

源码托管地址: https://github.com/donetsoftwork/Shadow。

如果大家喜欢请动动您发财的小手手帮忙点一下Star。

相关推荐
沛沛老爹10 天前
Python Django全功能框架开发秘籍
python·django·orm·web开发·模板引擎·项目部署·表单处理
掉头发的王富贵16 天前
【JOOQ】同事凭什么说它是世界上最好用的ORM框架
后端·mybatis·orm
o0向阳而生0o20 天前
68、.NET Entity Framework(EF)
.net·orm·ef
xiangji24 天前
.net 实现 CQRS 的的一个设想
orm·sqlbuilder
却尘1 个月前
当全世界都在用 Rust 重写一切时,Prisma 却选择了反方向
前端·数据库·orm
喵个咪1 个月前
开箱即用的GO后台管理系统 Kratos Admin - 代码生成工具集
微服务·orm·protobuf
xiangji1 个月前
ShadowSql.net之正确使用方式
orm·dapper·可扩展·sqlbuilder·面向接口
MyikJ1 个月前
Java求职面试:从Spring到微服务的技术挑战
java·数据库·spring boot·spring cloud·微服务·orm·面试技巧
Jaising6661 个月前
Mybatis Plus 多租户实现思路分析
spring boot·mybatis·orm
xiangji1 个月前
ShadowSql之表达式树
orm·sqlbuilder