Oracle 中可以使用标准方法(8i版本以上),也可以使用非标准的 ROWNUM ; MS SQL Server 则在 2005 版本中提供了 ROW_NUMBER() 函数;但在 MySQL 中似乎还没有这样的系统自带功能。 解决方法是通过预定义用户变量来实现: mysql set @mycnt = 0; mysql select (@mycnt := @mycnt + 1) as ROWNUM ,NAME fromCHARBASE LIMIT 100; 这样查询出来的结果集中 ROWNUM 就保存了行编号信息。这个行编号信息的某种用途在于当你需要根据需要对数据按照某种规则排序并取出排序之后的某一行数据,并且希望知道这行数据在之前排序中的位置时就用得着了。 为了方便,我们通常将两句合起来执行,以避免变量全局自增:
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、成都小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了台山免费建站欢迎大家使用!
mysql本身是没有行号的。要想得到查询语句返回的列中包含一列表示该行记录在整个结果集中的行号可以通过自定义set一个变量,然后每条记录+1的方式,返回这个变量的值。
举例:
表名为:s_ave
表的内容:
Ave Avename
1 d
3 e
4 a
6 b
5 e
我们要查询 ave=6 的行号:
set @mytemp = 0;
select * from (
SELECT (@mytemp:=@mytemp+1) as newid,Ave,Avename FROM s_ave
) AS A
WHERE A.Ave=6
自己试一下吧,这里 mytemp 的值就是行号
转自:
看你的意思行号就是显示顺序号,你的查询结果可以按id升序排序(order by id),这样查询结果的顺序就是显示的顺序,这个行号可以在程序里加上,不用在数据库操作。另外最好是加上一个排序值得字段,这样可以随时调整显示顺序。
获取第一个B的id
select id from 表
where type='b'
order by id
limit 0,1 --这个就是mysql的行数筛选,同msSQL的top效果.0指要从0+1位开始,1指返回一行.
取到这个以后再联回原表,或得当成子查询的条件,让ID小于筛选出的这个ID就行了.
DB2数据库不提供行号的查询,如果你真的需要行号的话,可以在表中增加一个自增长的列,每插入一条数据,该列自动增加1,相当于行号,不过这样的话,效率会比较低。
sqlserver中输出行号:row_number over()
而在mysql中没有排序函数,应该使用:
SET @rownum = 0;
SELECT (@rownum := @rownum + 1) AS ROWNUM , 表名.* FROM 表名;
验证