MySQL中在查询结果集中得到记录行号的方法
如果需要在查询语句返回的列中包含一列表示该条记录在整个结果集中的行号,ISOSQL:2003标准提出的方法是提供ROW_NUMBER()/RANK()函数。Oracle中可以使用标准方法(8i版本以上),也可以使用非标准的ROWNUM;MSSQLServer则在2005版本中提供了ROW_NUMBER()函数;但在MySQL中似乎还没有这样的系统自带功能。虽然LIMIT可以很方便的对返回的结果集数量和位置进行过滤,但过滤出来的记录的行号却没办法被SELECT到。据说MySQL是早就想增加这个功能了,但我是还没找到。
解决方法是通过预定义用户变量来实现:
set@mycnt=0; select(@mycnt:=@mycnt+1)asROWNUM,othercolfromtblnameorderbyothercol;
这样查询出来的结果集中ROWNUM就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。比如:
set@mycnt=0; select*from( select(@mycnt:=@mycnt+1)asROWNUM,othercol fromtblnameorderbyothercol )asAwhereothercol=OneKeyID;
当然你也可以通过创建临时表的方法把查询结果写到某个拥有auto_increment字段的临时表中再做查询,但考虑到临时表在MySQLmaster/slave模式下可能产生的问题,用这样临时用户定义变量的方式来计算查询结果集每一行对应的行号还是更为简洁--除非你愿意在PHP或其他语言脚本中对返回的整个结果集再作处理。