SQL开窗函数

文章目录

开窗函数(分析函数)

写法

复制代码
分析函数名() OVER(分析子句)

分析函数名

聚合类:

SUM AVG MIN MAX COUNT

排序类:

row_number()

RANK()

dense_rank()

分析子句

PARTITION BY 分组内容

ORDER BY 排序内容

ROWS 窗口(用的不多)

聚合类:

SUM AVG MIN MAX COUNT --聚合开窗

例题:查询员工的姓名岗位薪资以及该员工对应的部门平均薪资

复制代码
SELECT ename,job,sal,AVG(sal) OVER(PARTITION BY deptno) a FROM emp;

练习:

查询员工工资比该员工所在岗位平均薪资高的员工信息

复制代码
SELECT *
  FROM (SELECT EMP.*, AVG(SAL) OVER(PARTITION BY JOB) A FROM EMP)
 WHERE SAL > A;

注意:

1.聚合开窗的时候,分析函数名必须有内容,即AVG() 括号里必须要有东西

2.分析子句没有要求

排序类:

row_number()

RANK()

dense_rank() --排序开窗

区别

复制代码
SELECT ENAME,
       SAL,
       DEPTNO,
       ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY SAL),--不考虑并列  1234567
       RANK() OVER(PARTITION BY DEPTNO ORDER BY SAL), --考虑并列 跳过并列1224567
       DENSE_RANK() OVER(PARTITION BY DEPTNO ORDER BY SAL) --考虑并列,不跳过并列 1223456
       FROM emp;

练习:查询每个部门工资的前两名

复制代码
SELECT *
  FROM (SELECT ENAME,
               RANK() OVER(PARTITION BY DEPTNO ORDER BY SAL) A,
               DEPTNO
          FROM EMP)
 WHERE A <= 2

注意:

1.分析函数名内是不需要有东西的

2.分析子句里必须有 order BY

偏移类

LAG() LEAD() --偏移开窗

尚未学习

相关推荐
技术宝哥19 分钟前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸2 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
不知几秋2 小时前
sqlilab-Less-18
sql
dddaidai1232 小时前
Redis解析
数据库·redis·缓存
数据库幼崽2 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd2 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou3 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh3 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵5 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多5 小时前
Linux——mysql主从复制与读写分离
数据库·mysql