您的位置:首页 > 数据库 > MySQL

MySQL 数据库生成自动增长序号

2017-08-17 09:35 519 查看
Oracle 数据库中有 ROWNUM 这个功能,查询 list 后生成序号,很是方便,但 MySQL 是模拟了 Oracle 和 SQL Server 中的大部分功能,可自动生成序号却没有现成的函数或伪序列,很多情况下最后只能在后端代码或者前端代码中实现了。

要想在 MySQL 中直接用 SQL 查出自动增加的序号,方法倒是有,参见方法二,不像其它数据库,用一个序列或者函数就搞定了!

方法一:在程序中实现。

可以在代码中实现,如 Java、C、PHP、ASP、JS,无非也就是定义一个变量,循环整个 List,让变量递增即可。比如在页面上模拟序号显示,代码如下:

<s:iterator value="#request.list" var="v" status="status">
<tr>
<td align="center">
${status.index+1 }
</td>
</tr>
</s:iterator>


方法二:使用 MySQL 变量。

注意:@rownum 变量是 connection 级的,再次查询的时候需要初始化,否则序号每查询一次,会在前一次的基础上递增,所以需要 set @rownum=0。

SELECT
@rownum:=@rownum+1 AS rownum,
info.*
FROM (SELECT
@rownum:=0) r,
(SELECT *
FROM 表) info
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql 数据库 序号
相关文章推荐