如果需要在查询语句返回的列中包含一列表示该条记录在整个结果集中的行号
ISO SQL:
标准提出的方法是提供 ROW_NUMBER() / RANK() 函数
Oracle 中可以使用标准方法(
i版本以上)
也可以使用非标准的 ROWNUM
MS SQL Server 则在
版本中提供了 预定义用户变量来实现
set @mycnt = ;
select (@mycnt := @mycnt + ) as ROWNUM othercol from tblname order by othercol;
这样查询出来的结果集中 ROWNUM 就保存了行编号信息这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据并且希望知道这行数据在之前排序中的位置时就用得着了比如
set @mycnt = ;
select * from (
select (@mycnt := @mycnt + ) as ROWNUM othercol
from tblname order by othercol
) as A where othercol=OneKeyID;
当然你也可以通过创建临时表的方法把查询结果写到某个拥有 auto_increment 字段的临时表中再做查询但考虑到临时表在 MySQL master / slave 模式下可能产生的问题用这样临时用户定义变量的方式来计算查询结果集每一行对应的行号还是更为简洁 除非你愿意在 PHP 或其他语言脚本中对返回的整个结果集再作处理