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

相关推荐
wgzrmlrm7411 分钟前
如何解决ORA-28040没有匹配的验证协议_sqlnet.ora版本兼容设置
jvm·数据库·python
一江寒逸12 分钟前
零基础从入门到精通MySQL(附加篇):面试八股文全集
数据库·mysql·面试
数厘18 分钟前
2.6MySQL库表操作指南(电商数据分析专用)
数据库·mysql·数据分析
需要点灵感18 分钟前
SQL Server 存储过程语法整理
数据库·sql
刘~浪地球21 分钟前
数据库与缓存--分库分表实战指南
网络·数据库·缓存
Mr_Xuhhh26 分钟前
深入Java多线程进阶:从锁策略到并发工具全解析
前端·数据库·python
数厘32 分钟前
2.5可视化工具与 MySQL 连接配置及基础操作
数据库·mysql
沃尔威武1 小时前
性能调优实战:从火焰图定位到SQL优化的全流程
android·数据库·sql
数厘1 小时前
2.7SQL 四大分类:理解与避坑
数据库·sql
亮子AI1 小时前
【PostgreSQL】推荐几个PostgreSQL管理工具
数据库·postgresql