sql 常用语法

1、with as 递归查询

通过UNION ALL 连接部分。通过连接自身whit as 创建的表达式,它的连接条件就是递归的条件。可以从根节点往下查找,从子节点往父节点查找。只需要颠倒一下连接条件。例如代码中条件改为t.ID = c.ParentId即可

复制代码

with tree as(

--0 as Level 定义树的层级,从0开始

select *,0 as Level

from ClassUnis

where ParentId is null

union all

--t.Level + 1每递归一次层级递增

select c.*,t.Level + 1

from ClassUnis c,tree t

where c.ParentId = t.ID

--from ClassUnis c inner join tree t on c.ParentId = t.ID

)

select * from tree where Author not like'%/%'

2、分页查询

DECLARE @PageNumber AS INT, @RowspPage AS INT

SET @PageNumber = 1

SET @RowspPage = 10

SELECT *

FROM F1_WorkflowApplications

ORDER BY CreationTime

OFFSET (@PageNumber - 1) * @RowspPage ROWS

FETCH NEXT @RowspPage ROWS ONLY;

3、分组统计并合计总数及排序

SELECT isnull(MsgType,'总数'), COUNT(*) AS Total FROM dbo.BusinessMessages

Where CreationTime>='2024-01-01'

GROUP BY MsgType

WITH ROLLUP

Order by MsgType desc

WITH ROLLUP 和 WITH cube

ROLLUPCUBE的区别就是: ROLLUP 只会去统计group by 后面的第一个字段每个分组的小计和第一个字段的总计,而CUBE 统计group by 后面的每一个字段分组的小计和第一个字段的总计

以下举例可进行对比:

SELECT MsgType,ReceiveUserId, COUNT(*) AS Total FROM dbo.BusinessMessages

Where CreationTime>='2024-01-01'

GROUP BY MsgType,ReceiveUserId

with rollup

Order by MsgType desc

SELECT MsgType,ReceiveUserId, COUNT(*) AS Total FROM dbo.BusinessMessages

Where CreationTime>='2024-01-01'

GROUP BY MsgType ,ReceiveUserId

WITH cube

Order by MsgType desc,ReceiveUserId desc

GROUPING SETS

说明:GROUPING SETS 子句允许你指定多个GROUP BY选项,可以通过一条SELECT语句实现复杂繁琐的多条SELECT语句的查询,并且更加的高效。

GROUPING SETS 的 GROUP BY 子句可以生成一个等效于由多个简单 GROUP BY 子句的 UNION ALL 生成的结果集。

GROUPING SETS 可以生成等效于由简单 GROUP BY、ROLLUP 或 CUBE 操作生成的结果。

举例:

SELECT MsgType,ReceiveUserId,AppID, COUNT(*) AS Total,sum(cast(ReadTag as int)) as rr FROM dbo.BusinessMessages

Where CreationTime>='2024-01-01'

GROUP BY GROUPING SETS(

(MsgType, ReceiveUserId,AppID),

(MsgType, ReceiveUserId),

(MsgType)

)

相关推荐
herinspace1 分钟前
管家婆云辉煌开单优化
服务器·数据库·电脑·管家婆软件·财务软件
码云骑士3 分钟前
24-Django请求全链路-WSGI到数据库响应的完整旅程
数据库·python·django
霖霖总总6 分钟前
[MongoDB小技巧09]深入浅出 MongoDB 逻辑运算符:$and、$or、$nor、$not 原理与实战
数据库·mongodb
小丶舟7 分钟前
MiMo Code实测:5场景对标Claude Code,3个踩坑与选型指南
数据库·人工智能·数据挖掘
z_鑫10 分钟前
深入理解MyBatis:collection集合封装的底层原理与实现细节
java·开发语言·数据库·spring boot·mybatis
uoKent18 分钟前
Redis环境搭建与redis-cli基础操作
数据库·redis·缓存
倔强的石头10622 分钟前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
java·数据库·架构
Omics Pro24 分钟前
中医临床决策5款大语言模型,谁主沉浮?
数据库·人工智能·机器学习·语言模型·自然语言处理·chatgpt
BomanGe1025 分钟前
NSK NH35EM 高负载法兰型直线导轨详述
服务器·网络·数据库·经验分享·规格说明书
何极光28 分钟前
MySQL 8.0详细安装教程(附下载地址)
数据库·mysql·adb