Java获取数据库自增主键表中插入数据的ID

这段代码是为了解决,JDBC中在给自增表插入数据后获取插入数据自动生成的ID问题。上网找了半天资料,原来在JDK中有提供方法哎。

参考资料点击打开链接感谢诸位高手的指点。

1.

直接上代码吧:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.  * 自增主键主键插入值后获取自增ID 
  3.  * @param sql 
  4.  * @return 
  5.  */  
  6. public int insertIntoDB(String sql){  
  7.     Connection conn = null;  
  8.     Statement state = null;  
  9.     ResultSet rs = null;  
  10.     int key = -1;  
  11.     try{  
  12.         conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/jx3""root""root");  
  13.         state = conn.createStatement();  
  14.         state.executeUpdate(sql, Statement.RETURN_GENERATED_KEYS);  
  15.         rs = state.getGeneratedKeys();  
  16.         if(rs.next()){  
  17.             key = rs.getInt(1);  
  18.         }  
  19.         return key;  
  20.     }catch (SQLException e) {  
  21.         e.printStackTrace();  
  22.         return key;  
  23.     }finally{  
  24.         try{  
  25.             if(rs != null){  
  26.                 rs.close();  
  27.                 rs = null;  
  28.             }  
  29.             if(state != null){  
  30.                 state.close();  
  31.                 state = null;  
  32.             }  
  33.             if(conn != null){  
  34.                 conn.close();  
  35.                 conn = null;  
  36.             }  
  37.         }catch (SQLException e) {  
  38.             e.printStackTrace();  
  39.         }  
  40.     }  
  41. }  

2.如果你想提前知道这条数据插入的ID,你可以
在数据库中专门建立一张表存储各个表的最后一条数据的ID,直接使用存储过程(call test_getNextID)获取Id.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值