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

该工具的作用就是帮忙码农拼写sql,对标开源项目SqlKata。该工具最适合搭配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。

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

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

正在开发的.net sql拼写神器的更多相关文章

  1. iOS开发数据库篇—SQL

    iOS开发数据库篇—SQL 一.SQL语句 如果要在程序运行过程中操作数据库中的数据,那得先学会使用SQL语句 1.什么是SQL SQL(structured query language):结构化查 ...

  2. iOS开发数据库篇—SQL代码应用示例

    iOS开发数据库篇—SQL代码应用示例 一.使用代码的方式批量添加(导入)数据到数据库中 1.执行SQL语句在数据库中添加一条信息 插入一条数据的sql语句: 点击run执行语句之后,刷新数据 2.在 ...

  3. 使用Java注解开发自动生成SQL

    使用注解开发的好处就是减少配置文件的使用.在实际过程中,随着项目越来越复杂,功能越来越多,会产生非常多的配置文件.但是,当配置文件过多,实际维护过程中产生的问题就不容易定位,这样就会徒劳的增加工作量. ...

  4. 功能齐全、效率一流的免费开源数据库导入导出工具(c#开发,支持SQL server、SQLite、ACCESS三种数据库),每月借此处理数据5G以上

    软件名:DataPie 功能:支持SQL server.SQLite.ACCESS数据库的导入.导出.存储过程调用,支持EXCEL2007.EXCEL2003.ACCESS2007. CSV文件导入数 ...

  5. AgileEAS.NET SOA中间件平台/敏捷软件开发平台 and SQL详解

    AgileEAS.NET SOA中间件平台/敏捷软件开发平台 http://www.smarteas.net/ SQL详解: http://www.w3school.com.cn/sql/func_d ...

  6. 开发反模式 - SQL注入

    一.目标:编写SQL动态查询 SQL常常和程序代码一起使用.我们通常所说的SQL动态查询,是指将程序中的变量和基本SQL语句拼接成一个完整的查询语句. string sql = SELECT * FR ...

  7. 【转】Android开发之数据库SQL

    android中的应用开发很难避免不去使用数据库,这次就和大家聊聊android中的数据库操作. 一.android内的数据库的基础知识介绍 1.用了什么数据库 android中采用的数据库是SQLi ...

  8. spring boot整合mybatis基于注解开发以及动态sql的使用

    让我们回忆一下上篇博客中mybatis是怎样发挥它的作用的,主要是三类文件,第一mapper接口,第二xml文件,第三全局配置文件(application.properties),而今天我们就是来简化 ...

  9. 慕课网笔记之oracle开发利器-PL/SQL基础

    实例1--if语句 /* 慕课网Oracle数据库开发必备之PL/SQL_2-3 判断用户从键盘输入的数字 1.如何使用if语句 2.接收一个键盘的输入(字符串) */ set serveroutpu ...

  10. PL/SQL开发中动态SQL的使用方法

    一般的PL/SQL程序设计中,在DML和事务控制的语句中可以直接使用SQL,但是DDL语句及系统控制语句却不能在PL/SQL中直接使用,要想实现在PL/SQL中使用DDL语句及系统控制语句,可以通过使 ...

随机推荐

  1. Arcgis加载Geoserver矢量切片

    原帖地址 洒家废物 - Arcgis加载Geoserver矢量切片 准备点线面图层并发布图层组 此处我准备了石家庄市的县界名称(点).高速公路(线).县界(面),依次发布geoserver服务,创建图 ...

  2. WPF Play Image slider animation using Storyboard

    using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using Sys ...

  3. JVM监控工具使用

    1. 描述 ​ 程序在开发过程中,有可能会发生CPU飙高.内存溢出等问题或系统在后期调优阶段,不可避免的要监控JVM情况,JDK自带的Jconsole监控工具,结合Tomcat使用非常方便,占用内存小 ...

  4. VueJs(2)---操作指南

    VueJs(9)---组件(父子通讯) 组件(父子通讯) 一.概括 在一个组件内定义另一个组件,称之为父子组件. 但是要注意的是:1.子组件只能在父组件内部使用(写在父组件tempalte中); 2. ...

  5. tar基本命令

    常用基本命令 压缩文件 # touch a.txt # tar -czvf test.tar.gz a.txt  //或  tar -czvf /path/to/file.tar.gz file 列出 ...

  6. Markers pg walkthrough Intermediate

    发现是个md 变成pdf 的功能站 上网查exp 发现先了一个有用的 https://security.snyk.io/vuln/SNYK-JS-MARKDOWNPDF-5411358 能够任意文件读 ...

  7. 「NOIP2024」 树上查询

    update 2024/12/28 题目描述 给定一棵树,每次询问区间 \([l,r]\) 的 \[\max_{l \le l' \le r' \le r \land r' - l' + 1 \ge ...

  8. h5按需引入Vant

    下载按需引入插件(推荐) babel-plugin-import 是一款 babel 插件, 它会在编译过程中将 import 的写法自动转换为按需引入的方式 # 安装插件 npm i babel-p ...

  9. Linux安装Jenkins指南

    Linux安装Jenkins指南 Jenkins,作为一款开源的自动化服务器,广泛用于持续集成和持续部署(CI/CD)流程中.它提供了强大的插件生态系统,使得集成各种开发工具.版本控制系统和构建工具变 ...

  10. Transformer-Squared:停止微调 LLMs

    Transformer-Squared:停止微调 LLMs 自适应大语言模型背后的架构.Transformer-Squared 的数学与代码,以及奇异值分解 DALL-E 生成的图片 我们已经进入了这 ...