MySQL中自增长序列(@i:=@i+1)的用法示例详解

 更新时间:2025年07月16日 09:05:05   作者:楼兰胡杨  
本文介绍如何在MySQL中通过用户变量@i模拟Oracle的ROWNUM伪列,生成自增序列,适用于单表或多表查询场景,感兴趣的朋友一起看看吧

问题分析

   Oracle中的伪列 ROWNUM 是一组递增的序列,在查询数据时生成,为结果集中每一行标识一个行号, 每条记录会因为输出的顺序不同而获得不同的逻辑编号;此自增长序列可以视作起始值为 1,以1为步长的递增的等差数列。MySQL中没有这个伪列的概念,但是有些业务场景需要这个自增长编号,所以,本文分享如何在MySQL中模拟生成一个自增长序列。

模拟自增长序列

  单表查询

  sql示例:

select (@i:=@i+5) as rownum, surname, personal_name from student, (select @i:=100) as init;

   解释: 上述sql中,@i:=100为自定义的初始值为100,表名init可以自定义;(@i:=@i+5)为递增规则,表示递增序列的步长为5,上述sql运行结果如下:

  当然一般不会这么用,简单的从1开始递增就行:

select (@i:=@i+1) as rownum, surname, personal_name from student, (select @i:=0) as init;

  多表关联查询

  多表关联查询跟单表查询类似,在关联查询后定义一个自增长序列即可:

select (@i:=@i+1) as rownum, A.surname, B.uname from student A left join user B on CONCAT(A.surname, A.personal_name) = B.uname, (select @i:=0) as init;

结束语

  本文分享在MySQL中,使用 (@i:=@i+1) 模拟Oracle中的伪列 ROWNUM,生成一个自增长序列。

  以上就是这篇文章的全部内容了,希望本文对大家的学习或者工作能带来一定的帮助,如有疑问请留言交流。Wiener在此祝各位生活愉快!工作顺利!

Reference

到此这篇关于MySQL中自增长序列(c)的用处及用法的文章就介绍到这了,更多相关mysql @i:=@i+1用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql优化之like和=性能详析

    mysql优化之like和=性能详析

    这篇文章主要给大家介绍了关于mysql优化之like和=性能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • update.where无索引导致MySQL死锁问题解决

    update.where无索引导致MySQL死锁问题解决

    这篇文章主要为大家介绍了update.where无索引导致MySQL死锁问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • mysql基于正则实现模糊替换字符串的方法分析

    mysql基于正则实现模糊替换字符串的方法分析

    这篇文章主要介绍了mysql基于正则实现模糊替换字符串的方法,结合具体实例对比分析了使用正则实现mysql字符串替换的注意事项与相关操作技巧,需要的朋友可以参考下
    2017-03-03
  • MySQL 的CASE WHEN 语句使用说明

    MySQL 的CASE WHEN 语句使用说明

    本文介绍下,在mysql数据库中,有关case when语句的用法,介绍了case when语句的基础知识,并提供了相关实例,供大家学习参考,有需要的朋友不要错过
    2011-10-10
  • mysql字符集和数据库引擎修改方法分享

    mysql字符集和数据库引擎修改方法分享

    使用虚拟主机空间上的phpmyadmin操作数据库的时候,如果看到phpmyadmin首页上显示的MySQL 字符集为cp1252 West European (latin1),当我们导入数据时就会出现乱码
    2012-02-02
  • MySQL中join查询的深入探究

    MySQL中join查询的深入探究

    数据库中的JOIN称为连接,连接的主要作用是根据两个或多个表中的列之间的关系,获取存在于不同表中的数据,下面这篇文章主要给大家介绍了关于MySQL中join查询的深入探究,需要的朋友可以参考下
    2022-11-11
  • MySql .frm数据库文件导入的问题

    MySql .frm数据库文件导入的问题

    手头有.frm 文件,怎样导入数据库啊?
    2009-07-07
  • navicat 8 创建数据库与创建用户分配权限图文方法

    navicat 8 创建数据库与创建用户分配权限图文方法

    navicat是一款不错的图形化管理mysql的工具,大家一般都是用phpmyadmin或直接命令行操作,对于不是很熟悉命令的朋友,就可以使用navicat这个工具了,方便操作。
    2011-04-04
  • 图文介绍mysql中:=和=的区别

    图文介绍mysql中:=和=的区别

    这篇文章主要给大家介绍了关于mysql中:=和=区别的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • mysql报错:Deadlock found when trying to get lock; try restarting transaction的解决方法

    mysql报错:Deadlock found when trying to get lock; try restarti

    这篇文章主要给大家介绍了关于mysql出现报错:Deadlock found when trying to get lock; try restarting transaction的解决方法,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-07-07

最新评论