你好,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 的值就是行号。
如果需要在查询语句返回的列中包含一列表示该条记录在整个结果集中的行号 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;
lishixinzhi/Article/program/MySQL/201405/30871
SELECT
b.*
FROM
article
LEFT JOIN (
SELECT
@rownum :=@rownum + 1 AS rownum,
article.*
FROM
(SELECT @rownum := 0) r,
article
) b ON article.id = b.id
mysql没有rownum,只能这样进行计算
sqlserver中输出行号:row_number over()
而在mysql中没有排序函数,应该使用:
SET @rownum = 0;
SELECT (@rownum := @rownum + 1) AS ROWNUM , 表名.* FROM 表名;
验证
看你的意思行号就是显示顺序号,你的查询结果可以按id升序排序(order by id),这样查询结果的顺序就是显示的顺序,这个行号可以在程序里加上,不用在数据库操作。另外最好是加上一个排序值得字段,这样可以随时调整显示顺序。