MySQL数据库基础篇SQL窗口函数示例解析教程


当前第2页 返回上一页

row_number(): 为不重复的连续排序,从1开始,为查询到的数据依次生成不重复的序号进行排序

基本语法——row_number() over(order by 需要排序的字段asc/desc);

rank(): 为跳跃排序,结果相同的两个数据并列,为下一个数据空出所占的名次,即相同排名会占位

基本语法——rank() over(order by 需要排序的字段 asc/desc);

dense_rank(): 为有重复的连续排序,结果相同的两个数据并列,不为下一个数据空出所占的名次,即相同排名不占位

基本语法——dense_rank() over(order by 需要排序的字段 asc/desc);

我们用一张图来表示这三者间的关系:

ntile()函数 + over()

基本语法: ntile(n) over(partition by…order by…)其中n表示被切分的段数。

ntile(n)用于将分组数据平均切分成n块,如果切分的每组数量不均等,则第一组分得的数据更多。

ntile()函数通常用于比如求年级前10%成绩的学生,则n取值为10,用where筛选出第一组的数据。

偏移函数 + over()

基本语法1:前N行:lead(str, n, default) over(partition by …order by …)

基本语法2:后N行:lag(str, n, default) over(partition by …order by …)

str表示字段名,n表示前/后n行数据,默认值为1,default表示如果取值范围已经超过整个表的返回值,可以不填,不填默认返回N/A。

偏移函数,用于取出同一字段的前N行数据或后N行数据,作为单独的列,这里需要特别注意一下的是,lead代表前N行,lag代表后N行。

以上就是MySQL数据库基础篇窗口函数示例解析教程的详细内容,更多关于MySQL窗口函数基础的资料请关注其它相关文章!

更多相关Mysql内容来自木庄网络博客


标签:Mysql

返回前面的内容

相关阅读 >>

mysql中的ip地址存储简单介绍

mysql查询函数之 为表和字段取别名

mysql数据库条件查询语句的使用方法介绍

mysql怎么换行?

centos下mysql默认密码忘记怎么办?

mysql之权限以及设计数据库案例讲解

linux安装jdk和tomcat以及mysql的图文教程

关于mysql无法启动以及cmd下mysql命令无法识别的问题详解

一篇文章带你深入了解mysql触发器

mysql的事务,隔离级别和锁用法实例分析

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...