如何在MySQL查询结果集中得到记录行号
核心提示:假设需要在查询语句返回的列中包括1列表示该条记录在全部结果集中的行号, ISO SQL:2003 标准提出的方法是提供 ROW_NUMBER() / RANK() 函数。 Oracle 中可使用标准方法(8i版本以上),也能够使用非标准的 ROWNUM ; MS SQL Server 则在 2005 版本中提供了 ROW_NUMBE
假设需要在查询语句返回的列中包括1列表示该条记录在全部结果集中的行号, ISO SQL:2003 标准提出的方法是提供 ROW_NUMBER() / RANK() 函数。 Oracle 中可使用标准方法(8i版本以上),也能够使用非标准的 ROWNUM ; MS SQL Server 则在 2005 版本中提供了 ROW_NUMBER() 函数;但在 MySQL 中仿佛还没有这样的系统自带功能。固然 LIMIT 可以很方便的对返回的结果集数目和位置进行过滤,但过滤出来的记录的行号却没办法被 SELECT 到。听说 MySQL 是早就想增加这个功能了,但我是还没找到。
解决方法是通过预定义用户变量来实现:
set @mycnt = 0;
select (@mycnt := @mycnt + 1) as ROWNUM , othercol from tblname order by othercol;
这样查询出来的结果集中 ROWNUM 就保存了行编号信息。这个行编号信息的某种用处在于当你需要根据需要对数据依照某种规则排序并取出排序以后的某1行数据,并且希看知道这行数据在之前排序中的位置时就用得着了。比如:
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 模式下可能产生的题目,用这样临时用户定义变量的方式来计算查询结果集每1行对应的行号还是更加简洁 -- 除非你愿意在 PHP 或其他语言脚本中对返回的全部结果集再作处理。
TAG:方法,函数,版本,标准,行号
评论加载中...
|