首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

教你用SQL实现统计排名

前言: 在某些应用场景中,我们经常会遇到一些排名的问题,比如按成绩或年龄排名排名也有多种排名方式,如直接排名、分组排名排名有间隔或排名无间隔等等,这篇文章将总结几种MySQL中常见的排名问题。...好在MySQL8.0增加了窗口函数,使用内置函数可以轻松实现上述排名。...MySQL8.0 利用窗口函数实现排名 MySQL8.0中可以利用 ROW_NUMBER(),DENSE_RANK(),RANK() 三个窗口函数实现上述三种排名,需要注意的一点是as后的别名,千万不要与前面的函数名重名...| 1001 | 89 | 8 | 6 | 8 | +--------+-------+-------+---------+---+ 总结: 本文给出三种不同场景下实现统计排名的...对比MySQL8.0,发现利用窗口函数可以更轻松实现排名,其实业务需求远远比我们举的示例要复杂许多,用SQL实现此类业务需求还是需要慢慢积累的。

1.1K10

MySQL统计信息简介

作者:王小龙@网易乐得DBA 原文地址: http://mp.weixin.qq.com/s/698g5lm9CWqbU0B_p0nLMw MySQL执行SQL会经过SQL解析和查询优化的过程,解析器将...查询优化器决定SQL如何执行,依赖于数据库的统计信息,下面我们介绍MySQL 5.7中innodb统计信息的相关内容。 MySQL统计信息的存储分为两种,非持久化和持久化统计信息。...二、持久化统计信息 5.6.6开始,MySQL默认使用了持久化统计信息,即INNODB_STATS_PERSISTENT=ON,持久化统计信息保存在表mysql.innodb_table_stats和mysql.innodb_index_stats...目前MySQL并没有提供直方图的功能,某些情况下(如数据分布不均)仅仅更新统计信息不一定能得到准确的执行计划,只能通过index hint的方式指定索引。...新版本8.0会增加直方图功能,让我们期待MySQL越来越强大的功能吧!

2.5K20

MySQL 中使用变量实现排名名次

title: MySQL 中使用变量实现排名名次 date: 2023-7-16 19:45:26 tags: - SQL 高级查询 一....只要数据有相同的排名就一样,排名依次排序(1,2,2,3,3,4,5,...)...如果相同,则将当前的排名(@currank)赋值给当前行的排名。...当出现相同的数据时,排名保持不变,但是保持不变的排名依旧会占用一个位置,也就是类似于(1,2,2,2,5)这种排名 思路: 当出现相同的数据时,排名保持不变,但是保持不变的排名依旧会占用一个位置,也就是类似于...(1,2,2,2,5)这种排名就是属于中间的三个排名是一样的,但是第五个排名按照上面一种情况是(1,2,2,2,3),现在则是排名相同也会占据排名的位置 SELECT obj_new.user_id,

15630

MySQL 统计信息简介

MySQL执行SQL会经过SQL解析和查询优化的过程,解析器将SQL分解成数据结构并传递到后续步骤,查询优化器发现执行SQL查询的最佳方案、生成执行计划。...查询优化器决定SQL如何执行,依赖于数据库的统计信息,下面我们介绍MySQL 5.7中innodb统计信息的相关内容。 MySQL统计信息的存储分为两种,非持久化和持久化统计信息。...二、持久化统计信息 5.6.6开始,MySQL默认使用了持久化统计信息,即INNODB_STATS_PERSISTENT=ON,持久化统计信息保存在表mysql.innodb_table_stats和mysql.innodb_index_stats...目前MySQL并没有提供直方图的功能,某些情况下(如数据分布不均)仅仅更新统计信息不一定能得到准确的执行计划,只能通过index hint的方式指定索引。...新版本8.0会增加直方图功能,让我们期待MySQL越来越强大的功能吧!

2.1K10

MySQL统计信息更新小结

参考材料:mysql官网文档:https://dev.mysql.com/doc/refman/8.0/en/innodb-persistent-stats.htmlhttps://dev.mysql.com...针对扫描行数,实际上MySQL在真正开始执行语句之前,并不能精确地知道满足这个条件的记录有多少条。它是通过统计信息来估算记录数的。这个统计信息就是索引的“区分度”。...MySQL使用“采样统计”的方式来维护统计信息。采样统计的时候,InnoDB默认会选择N个数据页,统计这些页面上的不同值,得到一个平均值,然后乘以这个索引的页面数,就得到了这个索引的基数。...在MySQL中,有两种存储索引统计的方式,可以通过设置参数innodb_stats_persistent的值来选择:设置为on的时候,表示统计信息会持久化存储。这时,默认的N是20,M是10。...MySQL 统计信息更新默认情况下innodb_stats_persistent=ON,优化器的统计信息会持久化保存在mysql.innodb_table_stats和mysql.innodb_index_stats

2.2K20

一文解决所有MySQL分类排名问题

本文介绍4种分类排名方式:子查询、自连接、自定义变量以及MySQL8.0窗口函数。 ? 01 需求介绍 考虑MySQL中的一个经典应用:给定一个学生考试成绩表,要实现对学生按课程依成绩高低进行排序。...02 子查询 实现这一需求的最直接想法是通过子查询,对每个分数进行统计统计表中有多少分数比其更高,那么该分数的排名就是更高分数计数+1。...如果要区分课程排名,那么统计表时只需增加一个限制课程id相等的约束条件即可。...:通过自定义变量(MySQL定义变量用@作为引导符,并用:=表示赋值)记录前一个排名、前一个分数值、当前的总排名,分别实现三种需求。...05 MySQL8.0窗口函数 MySQL8.0版本的一个重要更新就是增加了窗口函数,使得前面的分类排名需求变得异常简单。

3.5K60
领券