正在开发的.net sql拼写神器

我正在开发的一个.net sql拼写工具,当然也可以算是ORM

本工具的作用就是帮忙码农拼写sql,对标开源项目SqlKata。

本工具最大的特点就是性能好,省内存,拼接sql从头到尾只使用一个StringBuilder。

支持多种数据库,也可以自定义数据库方言,支持net7.0;net8.0;net9.0;netstandard2.0;netstandard2.1,支持跨平台。

本工具最适合搭配Dapper使用,所以附带了一个Dapper扩展。当然直接搭配ado.net也是可以的。

sql操作用的最多也是最复杂的是查询,本工具包含两套查询模式:sql模式和逻辑模式。

一、先介绍sql查询模式

1、支持按原生sql进行查询,示例如下:

复制代码
        var query = db.From("Users")
            .ToSqlQuery()
            .Where("Id=@Id", "Status=@Status");

2、支持按逻辑查询

复制代码
        var query = new UserTable()
            .ToSqlQuery()
            .Where(Id.EqualValue(100));

3、支持GroupBy

复制代码
        var table = db.From("Users");
        var groupBy = table.ToSqlQuery()
            .ColumnEqualValue("Age", 20)
            .GroupBy("CityId")
            .Having(g => g.Aggregate("MAX", "Level").GreaterValue(9));

4、支持联表

复制代码
        var employees = db.From("Employees");
        var departments = db.From("Departments");

        var joinOn = employees.SqlJoin(departments)
            .On(static (t1, t2) => t1.Field("DepartmentId").Equal(t2.Field("Id")));
        var joinTable = joinOn.Root
            .Where(join => join.From("t2").Field("Manager").EqualValue("CEO"));

二、逻辑模式

以上功能逻辑模式都支持,逻辑模式是按And、Or来查询的。没有where、having、on等关键字

逻辑模式一般执行速度更快、内存消耗更少

1、单表查询

复制代码
        var query = db.From("Users")
            .ToQuery()
            .And(_id.Equal())
            .And(_status.Equal("Status"));
复制代码
        var query = db.From("Users")
            .ToOrQuery()
            .Or(_id.Equal())
            .Or(_status.Equal("Status"));

2、GroupBy

复制代码
        var groupBy = table.ToQuery()
            .And(Age.EqualValue(20))
            .GroupBy("CityId")
            .And(Level.Max().GreaterValue(9));

3、联表

复制代码
        CommentTable c = new("c");
        PostTable p = new("p");
        var joinOn = c.Join(p)
            .And(c.PostId.Equal(p.Id));
        var query = joinOn.Root
            .And(c.Pick.Equal())
            .And(p.Author.Equal())

篇幅有限,还有很多功能没法在这里一一列举,欢迎大家去探索。

三、两种模式与SqlKata对比速度都更快,消耗内存也更少

更多信息可以到github上查询,或下载代码自己测试一下

四、源码托管在github上

仓库地址: https://github.com/donetsoftwork/Shadow

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

有什么建议也可以反馈给我,该项目还在开发中,还可能会增加更多有趣的功能。

而且我还计划为这个工具再开发一个精简版本,以求更好的性能。

相关推荐
XLYcmy6 天前
一个用于统计文本文件行数的Python实用工具脚本
开发语言·数据结构·windows·python·开发工具·数据处理·源代码
予枫的编程笔记6 天前
【MySQL筑基篇】从排名统计到非结构化存储:MySQL窗口函数与JSON实战教程
mysql·数据处理·窗口函数·后端开发·json数据类型·数据库进阶·mysql高级特性
ha_lydms7 天前
Hadoop 架构
大数据·hadoop·hdfs·架构·mapreduce·yarn·数据处理
Brduino脑机接口技术答疑8 天前
脑机接口数据处理连载(十四) 实时数据处理:低延迟算法设计与性能优化
算法·性能优化·数据处理·脑机接口
阿杰学AI9 天前
AI核心知识70——大语言模型之Context Engineering(简洁且通俗易懂版)
人工智能·ai·语言模型·自然语言处理·aigc·数据处理·上下文工程
千桐科技16 天前
qData 数据中台核心能力解析|第 02 期:从“有标准”到“能执行”,数据标准体系全景解析
数据处理·大数据平台·数据中台·逻辑模型·qdata·数据标准·标准登记
康谋自动驾驶19 天前
汽车多总线数据采集:挑战、架构与同步策略全解析
算法·自动驾驶·开发·数据处理·总线数据
杰瑞不懂代码1 个月前
使用pandas操作EXCEL表格入门教程
python·excel·pandas·办公自动化·数据处理
科研面壁者1 个月前
Origin科研绘图——3D 百分比堆积墙型图
3d·可视化·origin·数据处理·科研绘图
ha_lydms1 个月前
5、Spark函数_s/t
java·大数据·python·spark·数据处理·maxcompute·spark 函数