SQL PARTITION BY用法

文章目录

  • 一、前言
  • 二、案例
  • [三、与group by 对比](#三、与group by 对比)
  • 四、妙用
    • [4.1 接函数](#4.1 接函数)
    • [4.2 行号](#4.2 行号)
    • [4.3 count 另类](#4.3 count 另类)

一、前言

关于同表分组,今天发现Partition By 特好用,

相比于Group By,贵在保留原表所有行+灵活计算

二、案例

对于同表TableA 的不同分组计数,如:

sql 复制代码
SELECT *, 
(SELECT COUNT(1) TableA B  where A.COL1=B.COL1) AS COUNT1
(SELECT COUNT(1) TableA B  where A.COL1=B.COL1 AND  A.COL2=B.COL2 ) AS COUNT2
(SELECT COUNT(1) TableA B  where A.COL1=B.COL1 AND  A.COL2=B.COL2 AND A.COL3=B.COL3) AS COUNT3
FROM TableA A

使用PARTITION BY:

sql 复制代码
SELECT *, 
count(1) OVER  (PARTITION BY COL1) AS COUNT1
count(1) OVER  (PARTITION BY COL1,COL2)  AS COUNT2
count(1) OVER  (PARTITION BY COL1,COL2,COL3)  AS COUNT3
FROM TableA A

代码一下清爽了。

三、与group by 对比

实现计数

sql 复制代码
SELECT *, 
count(1) OVER  (PARTITION BY COL1) AS COUNT1
FROM TableA A

相当于

sql 复制代码
SELECT *, 
(SELECT COUNT(1) TableA B  where A.COL1=B.COL1 group by  COL1) AS COUNT1
FROM TableA A

四、妙用

4.1 接函数

sql 复制代码
SELECT 
    *,
    -- 计算总销
    SUM(amount) OVER (PARTITION BY COL1 ) AS total,
    -- 计算占比(保留2位小数)
    ROUND(COL3 / SUM(COL2 ) OVER (PARTITION BY COL1 ) * 100, 2) AS ratio
FROM TableA ;

4.2 行号

sql 复制代码
SELECT 
    *,
   ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2 DESC) 
FROM TableA ;

多一个行号列 1、2、3、4、5

4.3 count 另类

count 会遍历所有数据, 但是ROW_NUMBER()-1 只会取一条,

这未曾不是一种优化

sql 复制代码
SELECT 
    *,
   ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2 DESC) -1  as count1 
FROM TableA ;
--备注
SELECT 
    *,
   CASE when count1=0 Then 1 else 2 END  AS  '新产品'
FROM TableA ;

当然 还可以 MAX(count1)-1 作为 总条数的取值。

相关推荐
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横2 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据3 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡3 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧3 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon3 天前
SQL学习指南——视图
数据库·sql