现在位置: 首页 > 博客文章 > 电脑相关 > IT开发 > 数据库 > MySQL > 正文
MySQL生成自动增长序号
2014年07月29日 20:41:18 MySQL ⁄ 共 714字 暂无评论 ⁄ 被围观 3,090次

Oracle 数据库中有 ROWNUM 这个功能,查询 list 后生成序号,很是方便,但 MySQL 是模拟了 Oracle 和 SQL Server 中的大部分功能,可自动生成序号却实现不了,很是蛋疼,没办法,最后只能在 JS 画面上生成了。

要想在 MySQL 中直接用 SQL 查出自动增加的序号,方法倒是有,不过都得绞尽脑汁的想,不像 Oracle 等,一个函数就欧了!

方法一:在程序中实现。

可以在程序代码中,如 Java、C、PHP、ASP、JSP 等中自己模拟写,也就是定义一个变量,循环整个 List,让变量递增即可。我这里最后实在没法,就用 JSP 在画面上模拟出来的,代码如下:

Code   ViewPrint
  1. <s:iterator value="#request.list" var="v" status="status">  
  2.     <tr>  
  3.         <td align="center">  
  4.             ${status.index+1 }  
  5.         </td>  
  6.     </tr>  
  7. </s:iterator>  

 

方法二:使用 MySQL 变量。

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

Code   ViewPrint
  1. SELECT  
  2.   @rownum:=@rownum+1 AS rownum,  
  3.   info.*  
  4. FROM (SELECT  
  5.         @rownum:=0) r,  
  6.   (SELECT *  
  7.    FROM 表) info  

 

还是早些出个 ROWNUM 函数的好,期待中……

给我留言

留言无头像?