600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > MySQL中在查询结果集中得到记录行号办法【MySQL】

MySQL中在查询结果集中得到记录行号办法【MySQL】

时间:2019-03-23 07:57:35

相关推荐

MySQL中在查询结果集中得到记录行号办法【MySQL】

数据库|mysql教程

MySQL,查询结果集中得到记录行号

数据库-mysql教程

如果需要在查询语句返回的列中包含一列表示该条记录在整个结果集中的行号, ISO SQL: 标准提出的方法是提供 ROW_NUMBER() / RANK() 函数。 Oracle 中可以使用标准方法(8i版本以上),也可以使用非标准的 ROWNUM ; MS SQL Server 则在 版本中提供了 ROW_NUMBER() 函数;但在 MySQL 中似乎还没有这样的系统自带功能。虽然 LIMIT 可以很方便的对返回的结果集数量和位置进行过滤,但过滤出来的记录的行号却没办法被 SELECT 到。据说 MySQL 是早就想增加这个功能了,但我是还没找到。

易语言dll注入源码,ubuntu检查某个端口,tomcat本地部署特别慢,爬虫bug教学,php照片管理系统,新民电子抖音seo优化要多少钱lzw

解决方法是通过预定义用户变量来实现:

在线客服系统源码,vscode 前端,ubuntu u,tomcat并发,sqlite 字符串,网页设计模板下载,数据库连php,高防云服务器,jquery tab菜单插件,前端css框架,爬虫ip,php 代码,桂林seo,springboot微服务架构,video标签全屏,成品网站,简单网页模板,html网页模板,网站后台上传文件限制,返回页面顶部top按钮实例,小型超市管理系统java,ica matlab程序lzw

set @mycnt = 0;

select (@mycnt := @mycnt + 1) as ROWNUM , othercol from tblname order by othercol;

自适应文章管理系统源码,ubuntu 中文家目录,tomcat优化性能调优,淘宝爬虫算法,暴雪php时彩平台源码,shopify怎么seolzw

这样查询出来的结果集中 ROWNUM 就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。比如:

set @mycnt = 0;

select * from (

select (@mycnt := @mycnt + 1) as ROWNUM , othercol

from tblname order by othercol

) as A where othercol=OneKeyID;

当然你也可以通过创建临时表的方法把查询结果写到某个拥有 auto_increment 字段的临时表中再做查询,但考虑到临时表在 MySQL master / slave 模式下可能产生的问题,用这样临时用户定义变量的方式来计算查询结果集每一行对应的行号还是更为简洁 — 除非你愿意在 PHP 或其他语言脚本中对返回的整个结果集再作处理。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。