MySQL如何给查询结果添加行号

 更新时间:2024年07月27日 10:23:04   作者:BestTomDoG  
这篇文章主要介绍了MySQL如何给查询结果添加行号的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

MySQL给查询结果添加行号

SET @rownum:=0; -- 注意:“:=”表示赋值,“=”表示比较,“@”表示变量
 
SELECT provinces.*,@rownum:=@rownum+1 as rownum 
FROM provinces;
SELECT provinces.*,@rownum:=@rownum+1 as rownum
FROM provinces,(SELECT @rownum:=0) a;
 
-- MySQL8.0以上版本支持函数,和oracle数据库语法一样
SELECT provinces.*,row_number() over(ORDER BY id) as rownum
FROM provinces;

结果集

MySQL显示行号,以及分组排序

建表

CREATE TABLE `my_tb` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `parent_code` varchar(255) DEFAULT NULL,
  `code` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

初始数据

INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('01', '001');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('01', '002');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('02', '001');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('01', '003');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('02', '002');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('03', '001');
INSERT INTO `my_tb` (  `parent_code`, `code`) VALUES ('04', '001');

查询行号

-- 生成 行号
select @r:=@r+1 as row_num , a.* from  my_tb a ,(select @r:=0) b

显示分组号

-- 生成 分组排序号

select  
     @group_row:=CASE when @parent_code=a.parent_code then  @group_row+1 else 1 end as groupRow,
     @parent_code:=a.parent_code as parent_code,
     a.code  

  from  my_tb a ,( select @group_row:=1, @parent_code:='') as b
 ORDER BY   a.parent_code , a.code 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • Ubuntu查看修改mysql的登录名和密码、安装phpmyadmin

    Ubuntu查看修改mysql的登录名和密码、安装phpmyadmin

    这篇文章主要介绍了Ubuntu查看修改mysql的登录名和密码、安装phpmyadmin,本文分步骤给大家讲解的非常详细,需要的朋友可以参考下
    2019-11-11
  • MySQL中处理大数据表的3种方案的实现与对比

    MySQL中处理大数据表的3种方案的实现与对比

    这篇文章主要为大家详细介绍了MySQL中处理大数据表的3种方案的实现与对比,文中的示例代码讲解详细,有需要的小伙伴可以根据需要进行选择
    2025-10-10
  • SQL实现LeetCode(178.分数排行)

    SQL实现LeetCode(178.分数排行)

    这篇文章主要介绍了SQL实现LeetCode(178.分数排行),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 简单谈谈MySQL的半同步复制

    简单谈谈MySQL的半同步复制

    从MySQL5.5开始,MySQL以插件的形式支持半同步复制。如何理解半同步呢?今天我们就来详细讲解下,希望大家能够喜欢。
    2017-03-03
  • 深入sql多表差异化联合查询的问题详解

    深入sql多表差异化联合查询的问题详解

    本篇文章是对sql多表差异化联合查询的问题进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 集群rpm安装MySQL步骤详解

    集群rpm安装MySQL步骤详解

    在本篇文章里小编给大家整理的是一篇关于集群rpm安装MySQL步骤内容,需要的朋友们可以参考学习下。
    2020-01-01
  • MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    本文主要介绍了MySQL的索引类型,根据索引的存储方式来划分,索引可以分为聚簇索引和非聚簇索引。聚簇索引的特点是叶子节点包含了完整的记录行,而非聚簇索引的叶子节点只有所以字段和主键ID,感兴趣的同学可以阅读本文
    2023-04-04
  • MySQL8数据库安装及SQL语句详解

    MySQL8数据库安装及SQL语句详解

    本文详细讲解了MySQL8数据库安装及SQL语句用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • mysql 重要日志文件汇总

    mysql 重要日志文件汇总

    这篇文章主要介绍了mysql 重要日志文件的汇总,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-11-11
  • mysql8.0.12如何重置root密码

    mysql8.0.12如何重置root密码

    这篇文章主要为大家详细介绍了mysql8.0.12如何重置root密码,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11

最新评论