获得自动增长的MySQL主键

数据库 MySQL
如果需要获得MySQL数据库中自动增长的主键,应该如何实现呢?下文对该功能的实现方法作了详细的介绍供您参考学习。

下面的脚本教您如何获得自动增长的MySQL主键,如果您对MySQL主键方面感兴趣的话,不妨一看,相信对您学习MySQL主键方面会有所启迪。

  1. import java.sql.*;  
  2.  
  3. public class GetKey {  
  4.     ResultSet rs = null;  
  5.     Connection conn = null;  
  6.     Statement stmt = null;  
  7.  
  8.     // 加入同一个连接发生其他查询,Key会被重写所以不准确  
  9.     public void getId() {  
  10.         try {  
  11.             getConnect gc = new getConnect();  
  12.             conn = gc.getconn();  
  13.             Statement stmt = conn.createStatement();  
  14.             stmt.executeUpdate("insert into tb (name) values ('Key')");  
  15.             rs = stmt.executeQuery("SELECT LAST_INSERT_ID()");  
  16.             int autoIncKeyFromFunc = -1;  
  17.             if (rs.next()) {  
  18.                 autoIncKeyFromFunc = rs.getInt(1);  
  19.                 System.out.println("autoIncKeyFromFunc: " + autoIncKeyFromFunc);  
  20.             }  
  21.         } catch (Exception e) {  
  22.             System.out.print("有异常发生!");  
  23.         }  
  24.     }  
  25.  
  26.     // getGeneratedKeys()是每次创建一个Statement 实例,所以是安全的!  
  27.     public void getId_() {  
  28.         try {  
  29.             getConnect gc = new getConnect();  
  30.             conn = gc.getconn();  
  31.             stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY,  
  32.                     java.sql.ResultSet.CONCUR_UPDATABLE);  
  33.             stmt.executeUpdate("insert into tb (name) values ('x')");  
  34.             int autoIncKeyFromApi = -1;  
  35.             rs = stmt.getGeneratedKeys();  
  36.             if (rs.next()) {  
  37.                 autoIncKeyFromApi = rs.getInt(1);  
  38.                 System.out.println("Key returned from getGeneratedKeys():"  
  39.                         + autoIncKeyFromApi);  
  40.             }  
  41.         } catch (Exception e) {  
  42.             System.out.print("有异常发生!");  
  43.         }  
  44.     }  
  45.  
  46.     public static void main(String[] args) {  
  47.         GetKey get = new GetKey();  
  48.         get.getId();  
  49.         get.getId_();  
  50.     }  
  51. }  

 

 

 

【编辑推荐】

MySQL主键的设计原则

MySQL分区的优点

Mysql分区表对函数的限制

定义MySQL事务的例子

创建MySQL存储过程示例

责任编辑:段燃 来源: 互联网
相关推荐

2010-08-20 10:18:32

DB2自动增长主键

2010-08-10 17:10:46

2010-08-03 13:23:47

DB2自动增长主键

2010-08-19 13:14:17

DB2自动增长主键

2018-05-29 15:17:00

NFV虚拟化网络

2019-10-21 08:08:34

MySQL数据库主键

2010-09-07 13:04:20

DB2数据库

2009-07-16 11:21:19

ibatis主键自动生成

2010-10-11 11:25:26

MySQL主键

2009-07-28 12:48:50

.net获得当前插入行

2010-09-25 10:41:34

SQL SERVER主

2009-03-09 08:43:02

智能手机移动OS

2009-06-26 16:21:22

Oracle自动增长Hibernate

2010-10-08 11:52:29

2010-09-25 09:18:45

sql server主

2023-11-10 11:20:30

2010-11-22 10:29:42

MySQL字段自增长

2010-05-14 14:30:07

安装MySQL

2011-08-22 16:56:07

MySQL自动增长列

2011-03-22 10:36:39

Oracle数据库自动增长列
点赞
收藏

51CTO技术栈公众号