第六章:MySQL开窗函数
2021/5/15 19:25:46
本文主要是介绍第六章:MySQL开窗函数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
目录
- 1.创表语句
- 1.语法
- 2.建表语句
- 3.插入数据
- 2.row_number()over
- 需求1:查询基本信息,并新加一列,按照工资降序排列
- 需求2:查询基本信息,并新加一列,先以id分组再按照工资降序排列
- 需求3:查询基本信息,并新加一列,先以id分组再按照工资降序排列,并且排序数小于2
- 需求4:查询基本信息,并新加一列,以工资降序排列,并且选出年龄再13到16之间的;
- with 用法
- 3.rank()over
- 需求1:查询基本信息,并新加一列,按照工资降序排列
- 4.dense_rank()
- 需求1:查询基本信息,并新加一列,按照工资降序排列
- 5.nitle()分组函数
- 需求1:查询基本信息,并新加一列分成4组,按照工资降序排列
1.创表语句
1.语法
MySQL 8.0之后,开始支持开窗函数;
语法格式:row_number() over(partition by 分组列 order by 排序列 desc)
row_number() over()分组排序功能:
在使用 row_number() over()函数时候,over()里头的分组以及排序的执行晚于 where 、group by、 order by 的执行。
2.建表语句
create table TEST_ROW_NUMBER_OVER( id varchar(10) not null, name varchar(10) null, age varchar(10) null, salary int null );
3.插入数据
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,'a',10,8000); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,'a2',11,6500); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,'b',12,13000); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,'b2',13,4500); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'c',14,3000); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'c2',15,20000); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'d',16,30000); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(5,'d2',17,1800); insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,'d2',18,50000);
select * from TEST_ROW_NUMBER_OVER t;
2.row_number()over
需求1:查询基本信息,并新加一列,按照工资降序排列
select id,name,age,salary,row_number()over(order by salary desc) rn from TEST_ROW_NUMBER_OVER t
需求2:查询基本信息,并新加一列,先以id分组再按照工资降序排列
方法一:
select id,name,age,salary,row_number()over(partition by id order by salary desc) rn from TEST_ROW_NUMBER_OVER t;
方法二:
select * from (select id,name,age,salary,row_number() over(partition by id order by salary desc) rn from TEST_ROW_NUMBER_OVER) t1
需求3:查询基本信息,并新加一列,先以id分组再按照工资降序排列,并且排序数小于2
select * from (select id,name,age,salary,row_number() over(partition by id order by salary desc) rn from TEST_ROW_NUMBER_OVER) t1 where t1.rn<2
需求4:查询基本信息,并新加一列,以工资降序排列,并且选出年龄再13到16之间的;
select id,name,age,salary,row_number()over(order by salary desc) rn from TEST_ROW_NUMBER_OVER t where t.age between '13' and '16'
with 用法
with tabs as ( select id, name, age, salary, row_number()over(partition by id order by salary desc) rn from TEST_ROW_NUMBER_OVER t )
在使用over等开窗函数时,over里头的分组及排序的执行晚于“where,group by,order by”的执行。
3.rank()over
需求1:查询基本信息,并新加一列,按照工资降序排列
select id,name,age,salary,rank()over(order by salary desc) rn from TEST_ROW_NUMBER_OVER t
4.dense_rank()
需求1:查询基本信息,并新加一列,按照工资降序排列
select id,name,age,salary, DENSE_RANK() over(order by salary desc) rn from TEST_ROW_NUMBER_OVER t
5.nitle()分组函数
需求1:查询基本信息,并新加一列分成4组,按照工资降序排列
select id,name,age,salary, NTILE(4) over(order by salary desc) rn from TEST_ROW_NUMBER_OVER t
这篇关于第六章:MySQL开窗函数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-20部署MySQL集群入门:新手必读指南
- 2024-11-20部署MySQL集群教程:初学者指南
- 2024-11-20部署MySQL集群项目实战:新手教程
- 2024-11-20部署MySQL集群资料:新手入门教程
- 2024-11-20MySQL集群部署教程:入门级详解
- 2024-11-20MySQL集群教程:入门与实践指南
- 2024-11-20部署MySQL集群教程:新手入门指南
- 2024-11-20MySQL读写分离教程:轻松入门
- 2024-11-20部署MySQL集群入门:一步一步搭建你的数据库集群
- 2024-11-19部署MySQL集群学习:入门教程