前言

  FreeSql支持通过Sql语句配合ISelect生成最终的Sql语句,也可以执行原生自定义Sql语句,使操作更灵活;通过sql语句与Iselect配合使用更好控制sql语句;

简单查询

_freeSql.Select<Student>()
.WithSql(@"SELECT TOP 10 * FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC")
.ToList(); SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT TOP 10 * FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC ) a //指定字段
_freeSql.Select<Student>()
.WithSql(@"SELECT TOP 10 * FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC")
.ToList<object>("Name,Age");
SELECT Name,Age
FROM ( SELECT TOP 10 * FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC ) a
  
  当只需要各别字段时,需要将字段卸载Tolist()中,而非WithSql,WithSql中的sql语句会被包起来作为一个表,如果外层(Tolist中的字段)查询内层(WithSql中的字段)没有字段会报错
  以下是错误示例
_freeSql.Select<Student>()
.WithSql(@"SELECT TOP 10 Nmae,Age FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC")
.ToList("Id,Name");
SELECT a.[Id], a.[Name]
FROM ( SELECT TOP 10 Nmae,Age FROM dbo.Student
WHERE Age > 5 AND Status = 1
ORDER BY Age DESC ) a
 
 

分页

_freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student")
.WhereIf(true, "Age > 5")
.OrderBy(x => x.Age)
.Page(2, 10)
.ToList();
//SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM(SELECT * FROM dbo.Student) a
//WHERE(Age > 5)
//ORDER BY a.[Age]
//OFFSET 10 ROW
//FETCH NEXT 10 ROW ONLY
 
 

Union All

  FreeSql提供WithSql生成Union All查询,多个WithSql组合在一起会用Union All拼接,从而实现Union All
var sql1 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=1")
.ToSql();
//SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM(SELECT * FROM dbo.Student WHERE ClassId = 1) a
var sql2 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=2")
.ToSql();
//SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM(SELECT * FROM dbo.Student WHERE ClassId = 2) a //合并
_freeSql.Select<Student>()
.WithSql(sql1)
.WithSql(sql2)
.ToList();
//SELECT* from(SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM (SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
// FROM (SELECT* FROM dbo.Student WHERE ClassId= 1) a ) a) ftb //UNION ALL //SELECT* from(SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM (SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
// FROM (SELECT* FROM dbo.Student WHERE ClassId= 2) a ) a) ftb
 

拼接sql结果集

  利用ToSql拼接新的SQL,将ToSql后获得的sql语句使用IAdo执行,可以实现多个sql语句的拼接,最后使用ado执行sql,以union all为例
var sql3 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=1")
.ToSql();
var sql4 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=2")
.ToSql();
_freeSql.Ado.CommandFluent($"{sql3} UNION ALL {sql4}")
.ExecuteDataTable();
// SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM(SELECT * FROM dbo.Student WHERE ClassId = 1) a UNION ALL SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
//FROM(SELECT * FROM dbo.Student WHERE ClassId = 2) a

分页坑

  当有两个sql语句,使用WithSql拼接两个sql或使用Page分页会导致两个sql都被加上了分页
var sql5 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=1")
.ToSql();
var sql6 = _freeSql.Select<Student>()
.WithSql(@"SELECT * FROM dbo.Student WHERE ClassId=2")
.ToSql();
var sql7 = _freeSql.Select<Student>()
.WithSql(sql1)
.WithSql(sql2)
.Page(1, 10)
.ToSql(); SELECT * from (SELECT TOP 10 a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT * FROM dbo.Student WHERE ClassId=1 ) a ) a) ftb UNION ALL SELECT * from (SELECT TOP 10 a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT * FROM dbo.Student WHERE ClassId=2 ) a ) a) ftb

  

  可以看到在sql7生成的时候使用了Page(1,10),导致sql查询的时候添加了Top 10,而且两条查询语句都添加了!

  官方提供的解决方案是先将sql5和sql6先不分页生成sql7,最终执行的sql7的时候再分页,这样就能正确拼接两条sql语句再分页;

var sql7 = _freeSql.Select<Student>()
.WithSql(sql1)
.WithSql(sql2)
.ToSql();
_freeSql.Select<Student>()
.WithSql(sql7)
.Page(2, 10)
.ToList();
SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT * from (SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT * FROM dbo.Student WHERE ClassId=1 ) a ) a) ftb UNION ALL SELECT * from (SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
FROM ( SELECT * FROM dbo.Student WHERE ClassId=2 ) a ) a) ftb ) a
ORDER BY a.[Id]
OFFSET 10 ROW
FETCH NEXT 10 ROW ONLY

FreeSql学习笔记——12.执行Sql的更多相关文章

  1. CUBRID学习笔记 28 执行sql脚本文件

    一下命令在csql下执行. insert_commands.sql为sql脚本文件 ;CL ;READ insert_commands.sql ;RU 第一行的cl 清空命令缓存,等同clear第二行 ...

  2. Mybatis学习笔记12 - 动态sql之choose(when otherwise)标签

    choose (when, otherwise):分支选择:带了break的swtich-case 示例代码: 接口定义: package com.mybatis.dao; import com.my ...

  3. SQL反模式学习笔记12 存储图片或其他多媒体大文件

    目标:存储图片或其他多媒体大文件 反模式:图片存储在数据库外的文件系统中,数据库表中存储文件的对应的路径和名称. 缺点:     1.文件不支持Delete操作.使用SQL语句删除一条记录时,对应的文 ...

  4. SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题

    目标:减少SQL查询数据,避免使用一条SQL语句解决复杂问题 反模式:视图使用一步操作,单个SQL语句解决复杂问题 使用一个查询来获得所有结果的最常见后果就是产生了一个笛卡尔积.导致查询性能降低. 如 ...

  5. 并发编程学习笔记(12)----Fork/Join框架

    1. Fork/Join 的概念 Fork指的是将系统进程分成多个执行分支(线程),Join即是等待,当fork()方法创建了多个线程之后,需要等待这些分支执行完毕之后,才能得到最终的结果,因此joi ...

  6. SpringMVC:学习笔记(12)——ThreadLocal实现会话共享

    SpringMVC:学习笔记(12)——ThreadLocal实现会话共享 ThreadLocal ThreadLocal,被称为线程局部变量.在并发编程的情况下,使用ThreadLocal创建的变量 ...

  7. Spring源码学习笔记12——总结篇,IOC,Bean的生命周期,三大扩展点

    Spring源码学习笔记12--总结篇,IOC,Bean的生命周期,三大扩展点 参考了Spring 官网文档 https://docs.spring.io/spring-framework/docs/ ...

  8. Ext.Net学习笔记12:Ext.Net GridPanel Filter用法

    Ext.Net学习笔记12:Ext.Net GridPanel Filter用法 Ext.Net GridPanel的用法在上一篇中已经介绍过,这篇笔记讲介绍Filter的用法. Filter是用来过 ...

  9. golang学习笔记12 beego table name `xxx` repeat register, must be unique 错误问题

    golang学习笔记12 beego table name `xxx` repeat register, must be unique 错误问题 今天测试了重新建一个项目生成新的表,然后复制到旧的项目 ...

  10. Spring MVC 学习笔记12 —— SpringMVC+Hibernate开发(1)依赖包搭建

    Spring MVC 学习笔记12 -- SpringMVC+Hibernate开发(1)依赖包搭建 用Hibernate帮助建立SpringMVC与数据库之间的联系,通过配置DAO层,Service ...

随机推荐

  1. 使用PicGo存储markdown图片(阿里云或者github)

    PicGo代替极简图床 之前使用极简床图,但是后来好像挂了,真是一件悲伤的事,最近才发现了一个神器,开源的PicGo,已经有各个平台的版本了.链接如下:https://github.com/Molun ...

  2. ai大模型流式输出------基于SSE协议的长连接实现

    传统的http1.0请求开发,已经满足了我们日常的web开发.一般请求就像下图这样子,客服端发起一个请求(触发),服务端做出一个响应(动作): 有时会有诸如实时刷新,实时显示的场景,我们往往是客户端定 ...

  3. Nuxt.js 应用中的 afterResponse 事件钩子

    title: Nuxt.js 应用中的 afterResponse 事件钩子 date: 2024/12/6 updated: 2024/12/6 author: cmdragon excerpt: ...

  4. 《前端运维》一、Linux基础--12网络

    这是linux部分的最后一篇内容,我们一起来学习下Linux网络. 我们先看些命令吧: ifconfig,查看与配置网络状态. netstat,查询网络状态,常用选项如下: -t,列出TCP协议端口 ...

  5. CHDFS 安全便捷的大数据访问体验

    一.背景 云 HDFS(Cloud HDFS,CHDFS)是腾讯云提供的支持标准 HDFS 访问协议.卓越性能.分层命名空间的分布式文件系统. CHDFS 主要解决大数据场景下海量数据存储和数据分析, ...

  6. Electron 窗体 BrowserWindow

    http://jsrun.net/t/KfkKp https://www.wenjiangs.com/doc/tlsizw1dst https://www.w3cschool.cn/electronm ...

  7. vue cli2.x升级到3.x

    一.升级脚手架的方式 安装最新的cli,如果电脑有以前2.x版本的cli,不能直接更新,先要卸载. 1. 卸载之前vue-cli版本 npm uninstall -g vue-cli 2. 安装新版本 ...

  8. Lummmax 雷曼克斯 翔龙 X15 专业对讲机常用功能

    Lummmax 雷曼克斯 翔龙 X15 专业对讲机常用功能 工作模式切换 ESC/M 在频率模式 (VFO) 与信道模式之间切换 编辑信道 在频率模式 (VFO) 下,输入目标频率并进行相关设置之后, ...

  9. dockercompose配置ulimit

    在 Docker Compose 文件中设置 ulimit 的方法如下: 在 Docker Compose 文件的 services 块中,为您要设置 ulimit 的服务添加 ulimits 子块, ...

  10. 记一次单元测试问题com.sun.crypto.provider.HmacSHA1 cannot be cast to javax.crypto.MacSpi

    在用单元测试Junit测试部门的SDK时,有个md5鉴权步骤,出现了java.lang.ClassCastException: com.sun.crypto.provider.HmacSHA1 can ...