主页 > 知识库 > MySQL使用变量实现各种排序

MySQL使用变量实现各种排序

热门标签:智能电销机器人靠谱么 长安区违法建房地图标注 地图标注培训 南宋地图标注黄河华山 电销机器人公众号推送 昆明智能外呼系统中心 电销机器人说明书 手机用地图标注工具 安国在哪里办理400电话

核心代码

--下面我演示下MySQL中的排序列的实现
--测试数据
CREATE TABLE tb
(
score INT
);
INSERT tb SELECT 
5 UNION ALL SELECT 
4 UNION ALL SELECT 
4 UNION ALL SELECT 
4 UNION ALL SELECT 
3 UNION ALL SELECT 
2 UNION ALL SELECT
1;
--1.row_number式的排序
SET @row_number =0;
SELECT @row_number := @row_number+1 AS row_number,score 
FROM tb 
ORDER BY score DESC ;
+------------+-------+
| row_number | score |
+------------+-------+
|     1 |   5 |
|     2 |   4 |
|     3 |   4 |
|     4 |   4 |
|     5 |   3 |
|     6 |   2 |
|     7 |   1 |
+------------+-------+
--2.dense_rank式的排序
SET @dense_rank = 0,@prev_score = NULL;
SELECT @dense_rank :=IF(@prev_score=score,@dense_rank,@dense_rank+1) AS decnse_rank,
  @prev_score := score AS score 
FROM tb 
ORDER BY score DESC ; 
+-------------+-------+
| decnse_rank | score |
+-------------+-------+
|      1 |   5 |
|      2 |   4 |
|      2 |   4 |
|      2 |   4 |
|      3 |   3 |
|      4 |   2 |
|      5 |   1 |
+-------------+-------+
--3.rank式的排序
SET @row=0,@rank=0,@prev_score=NULL;
SELECT @row:=@row+1 AS ROW,
    @rank:=IF(@prev_score=score,@rank,@row) AS rank,
    @prev_score:=score AS score
FROM tb 
ORDER BY score DESC;
+------+------+-------+
| ROW | rank | score |
+------+------+-------+
|  1 |  1 |   5 |
|  2 |  2 |   4 |
|  3 |  2 |   4 |
|  4 |  2 |   4 |
|  5 |  5 |   3 |
|  6 |  6 |   2 |
|  7 |  7 |   1 |
+------+------+-------+

您可能感兴趣的文章:
  • win10下mysql 8.0.12 安装及环境变量配置教程
  • MySQL设置global变量和session变量的两种方法详解
  • mysql 5.6.23 安装配置环境变量教程
  • MySQL8新特性:持久化全局变量的修改方法
  • mysql查询语句中用户变量的使用代码解析
  • MySQL 声明变量及存储过程分析
  • 几个比较重要的MySQL变量
  • 浅谈MySQL存储过程中declare和set定义变量的区别
  • MySQL变量原理及应用实例

标签:南昌 东莞 长沙 武汉 吉安 江门 合肥 潜江

巨人网络通讯声明:本文标题《MySQL使用变量实现各种排序》,本文关键词  MySQL,使用,变量,实现,各种,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySQL使用变量实现各种排序》相关的同类信息!
  • 本页收集关于MySQL使用变量实现各种排序的相关信息资讯供网民参考!
  • 推荐文章