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 作为 总条数的取值。

相关推荐
l1t8 小时前
DeepSeek总结的将 Rust Delta Kernel 集成到 ClickHouse
数据库·clickhouse·rust
qq_283720058 小时前
万字深度:Chroma 向量数据库全解析 — 核心原理、实战操作、性能优化与工程最佳实践
数据库·性能优化
黄筱筱筱筱筱筱筱9 小时前
二进制包安装MySql服务
数据库
初心未改HD9 小时前
LLM应用开发之向量数据库详解
数据库·人工智能
键盘上的猫头鹰9 小时前
【从零学MySQL(三)】数据增删改(DML)及 SELECT 查询详解
数据库·mysql·数据分析
KaMeidebaby9 小时前
卡梅德生物技术快报|蛋白的过表达质粒构建与生信分析实验全流程复盘
前端·数据库·其他·百度·新浪微博
渣渣盟10 小时前
数据库之两段锁协议相关理论及应用
数据库·关系规范化·两段锁协议
LCG元10 小时前
Istio - 服务网格流量治理深度解析:灰度发布 / 故障注入配置实践
java·数据库·istio
SuniaWang10 小时前
《Agentx专栏》03-架构设计:AgentX的六层架构是如何生长出来的
java·数据库·redis·docker·ai·架构
键盘上的猫头鹰10 小时前
【从零学MySQL(二)】数据库基础操作、数据类型与约束(附Navicat演示)
数据库·mysql·数据分析·数据可视化