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。

相关推荐
Jabes.yang2 天前
互联网大厂Java求职面试实战解析(含技术场景与详解)
spring boot·微服务·面试·orm·技术栈·java se·jakarta ee
落木萧萧8256 天前
MyBatisGX 批量操作:比 MyBatis-Plus 和 MyBatis-Flex 更好用、更快
mybatis·orm
喵个咪11 天前
GoWind Toolkit Go后端代码生成 完整全流程实战
后端·go·orm
落木萧萧82514 天前
为什么我把 MyBatisGX 设计成现在这样
mybatis·orm
落木萧萧82519 天前
自动生成 SQL 会拖慢性能吗?实测 MyBatisGX、MyBatis、MyBatis-Plus、MyBatis-Flex
java·orm
斐夷所非19 天前
ORM | 框架原理、实操与应用选型
orm
写了20年代码的老程序员21 天前
写了 20 年 Java,我受够了 MyBatis 的 4 个瞬间
mybatis·orm
rising start1 个月前
InsightEdu - 轻量智能学习平台
javascript·axios·css3·html5·fastapi·orm·dify
码农刚子1 个月前
.NET 8 Web开发入门(四):注入燃料——Entity Framework Core 与 Code First 实战
数据库·orm·sql server
CSharp精选营1 个月前
.NET 8 Web开发入门(四):注入燃料——Entity Framework Core 与 Code First 实战
orm·sql server·数据库迁移·ef core·entity framework core·crud操作·code first