1.ROW_NUMBER() 函数

依次排序,没有并列名次。如

SELECT st.ID '学号', st.`NAME` '姓名', sc.SCORE '成绩', ROW_NUMBER() OVER(ORDER BY sc.SCORE DESC) '排名'
FROM Student st
LEFT JOIN Score sc ON sc.STUDNET_ID = st.ID

查询结果为

可以看出,尽管存在相同的成绩(98.0、91.0),但是排名并没有并列,而是按顺序依次排号。

2.RANK() 函数

有并列名次,且并列名次会占用序号,因此名次之间可能会有间隔。如

SELECT st.ID '学号', st.`NAME` '姓名', sc.SCORE '成绩', RANK() OVER(ORDER BY sc.SCORE DESC) '排名'
FROM Student st
LEFT JOIN Score sc ON sc.STUDNET_ID = st.ID

查询结果为

可以看出,相同的成绩(98.0、91.0)的排名是相同的(并列第2名、并列第5名),且并列的名次会占用序号,因此与它下一个名次之间会有间隔。

显然这种结果是最符合实际生活中的排名的。

3.DENSE_RANK() 函数

有并列名次,但并列名次不占用序号,因此名次都是紧密相连的。如

SELECT st.ID '学号', st.`NAME` '姓名', sc.SCORE '成绩', DENSE_RANK() OVER(ORDER BY sc.SCORE DESC) '排名'
FROM Student st
LEFT JOIN Score sc ON sc.STUDNET_ID = st.ID

查询结果为

可以看出,相同的成绩(98.0、91.0)的排名是相同的(并列第2名、并列第5名),但并列的名次并会占用序号,因此与它下一个名次之间没有间隔,所有名次都是紧密相连的。

4.NTILE() 函数

NTILE(n) 函数可以将返回的结果排序,如

SELECT st.ID '学号', st.`NAME` '姓名', sc.SCORE '成绩', NTILE(4) OVER(ORDER BY sc.SCORE DESC) '组号'
FROM Student st
LEFT JOIN Score sc ON sc.STUDNET_ID = st.ID

表示将成绩按从大到小排序后,把结果分为4组。由于总记录数为8条,因此每组会有2条记录:

这样每组的记录数是均匀的。

但如果查询结果的总记录数不能被指定的要分的组的总数整数,则分得的每组中的记录数是不均匀的,如

SELECT st.ID '学号', st.`NAME` '姓名', sc.SCORE '成绩', NTILE(3) OVER(ORDER BY sc.SCORE DESC) '组号'
FROM Student st
LEFT JOIN Score sc ON sc.STUDNET_ID = st.ID

由于 8 不能被 3 整除,因此得到的 3 组中每组的记录数不是完全一样的,而是按照 3、3、2 分配的,即"尽量"保证了均匀。

小白养成记——MySQL中的排名函数的更多相关文章

  1. 小白养成记——Linux中的用户和权限管理

    1.用户组管理 每个用户都属于一个用户组,系统可以对一个用户组中的所有用户进行集中管理. 在创建用户时,如果未指定组,则系统会创建一个与用户名同名的组. 以下是关于用户组管理的一些基本命令: 新建用户 ...

  2. Mysql中使用find_in_set函数查找字符串

    mysql有个表的字段的存储是以逗号分隔的,如domain字段login.s01.yy.com,s01.yy.com,s02.yy.com.现在要查找s01.yy.com这个.我们用like查找好像不 ...

  3. mysql中的group_concat函数的用法

    本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) . MySQL中group_concat函数 完整的语法如下: grou ...

  4. SQLServer 中实现类似MySQL中的group_concat函数的功能

    SQLServer中没有MySQL中的group_concat函数,可以把分组的数据连接在一起. 后在网上查找,找到了可以实现此功能的方法,特此记录下. SELECT a, stuff((SELECT ...

  5. SQL点滴20—T-SQL中的排名函数

    原文:SQL点滴20-T-SQL中的排名函数 提到排名函数我们首先可能想到的是order by,这个是排序,不是排名,排名需要在前面加个名次序号的,order by是没有这个功能的.还可能会想到ide ...

  6. mysql中的substr()函数

    mysql中的substr()函数和hibernate的substr()参数都一样,就是含义有所不同. 用法: substr(string string,num start,num length); ...

  7. Mysql中常用的函数汇总

    Mysql中常用的函数汇总: 一.数学函数abs(x) 返回x的绝对值bin(x) 返回x的二进制(oct返回八进制,hex返回十六进制)ceiling(x) 返回大于x的最小整数值exp(x) 返回 ...

  8. Mysql中使用聚合函数对null值的处理

    平时因为对于数据库研习的不深,所以在面试的时候问了一些平常遇到过的问题居然没法很肯定地回答出来,实在让自己很恼怒! 这次让我记忆深刻的一个问题是: 在mysql中使用聚合函数的时候比如avg(t),t ...

  9. Mysql中的常用函数:

    Mysql中的常用函数: 1.字符串函数: (1).合并字符串 concat():// concat('M','y',"SQL",'5.5');== MySQL5.5//当传入的参 ...

随机推荐

  1. Linux lsblk和df命令区别

    lsblk 查看的是block device,也就是逻辑磁盘大小. df查看的是file system, 也就是文件系统层的磁盘大小

  2. Codeforces Round #668 (Div. 2)【ABCD】

    比赛链接:https://codeforces.com/contest/1405 A. Permutation Forgery 题意 给出一个大小为 $n$ 的排列 $p$,定义 \begin{equ ...

  3. NOIP组合数选题

      前言: "所有的组合数问题都是好题" ----清华某高材生zhx 组合数问题在近几年的NOIP的考试中多次露面,感觉有必要好好学一学 组合数的常见公式:        C  ( ...

  4. 2020牛客暑期多校训练营(第二场) Boundary

    传送门:Boundary  题意:给你n个点的坐标,问最多有多少个点可以在同一个圆上,(0,0)必须在这个圆上. 题解:三个点确定一个圆,所以暴力枚举两个点和(0,0)组成的圆,如果三个点不共线的话, ...

  5. Selenium和ChromeDriver下载地址

    Selenium 官方所有版本: https://selenium-release.storage.googleapis.com/index.html 镜像所有版本:https://npm.taoba ...

  6. C# 同步和异步(概念理解)

    C#  同步和异步 IO 概念区分 四个相关概念: 同步(Synchronous) 异步( Asynchronous) 阻塞( Blocking ) 非阻塞( Nonblocking) 同步异步图解 ...

  7. echart关系图平分节点删除时自动平衡问题

    项目场景: 项目场景:Echarts关系图中(不是力图)一个节点x,y是固定的,为了同一列能居中显示,规定:当前列有奇数个元素新节点往下放,有偶数个节点时新节点往上放. 问题描述: 删除中间节点会有空 ...

  8. 利用windows api共享内存通讯

    主要涉及CreateFile,CreateFileMapping,GetLastError,MapViewOfFile,sprintf,OpenFileMapping,CreateProcess Cr ...

  9. IDEA 安装常用操作一

    关于IDEA的下载,破解自行百度 一.安装完成的常用设置 SDK选择.编译版本的选择,单项目选择,全局选择 maven配置,单项目,全局配置 二.IDEA如何安装lombok https://www. ...

  10. SPOJ SUBST1 New Distinct Substrings(后缀数组 本质不同子串个数)题解

    题意: 问给定串有多少本质不同的子串? 思路: 子串必是某一后缀的前缀,假如是某一后缀\(sa[k]\),那么会有\(n - sa[k] + 1\)个前缀,但是其中有\(height[k]\)个和上一 ...