码迷,mamicode.com
首页 > 其他好文 > 详细

插入一条记录并获取自增的id

时间:2014-10-28 23:43:25      阅读:360      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   color   ar   使用   for   sp   strong   

Connection connection = (Connection) dbcp.getConn();
                int affectRows = qr.update(connection, sql,params);
                BigInteger id = BigInteger.ZERO ;
                id = qr.query(connection, "SELECT LAST_INSERT_ID()", new ScalarHandler(1));  //获取新增记录的自增主键 

这个是通过dbutils来获取的方式来获取自增的id,记得connection必须是同一个,详解:

LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,再向表b插入数据,LAST_INSERT_ID会改变。

在多用户交替插入数据的情况下max(id)显然能用。这时就该使用LAST_INSERT_ID了,因为LAST_INSERT_ID是基于Connection的,只要每个线程都使用独立的 Connection对象,LAST_INSERT_ID函数将返回该Connection对AUTO_INCREMENT列最新的insert or update 操作生成的第一个record的ID。这个值能被其它客户端(Connection)影响,保证了你能够找回自己的 ID 而用担心其它客户端的活动,而且需要加锁。使用单INSERT语句插入多条记录, LAST_INSERT_ID返回一个列表。 

另一个是原生态的

PreparedStatement pstmt = conn.prepareStatement(strSQL,Statement.RETURN_GENERATED_KEYS);
            if(params!=null) {
                for(int i=0; i< params.length ;i++){
                    pstmt.setObject(i+1, params[i]);
                }
            }
            int affectedRows = pstmt.executeUpdate();
            ResultSet rsAutoId = pstmt.getGeneratedKeys();
            if (rsAutoId != null) {
                if (rsAutoId.next()) {
                    //刚插入数据的自增ID
                    System.out.println(rsAutoId.getInt(1));
                    // 6、返回结果
                    return rsAutoId.getInt(1);
                }
            }

 两个都与connection有直接的关联,所有不要换connection,更不要中途关闭连接!!!

插入一条记录并获取自增的id

标签:style   blog   io   color   ar   使用   for   sp   strong   

原文地址:http://www.cnblogs.com/dashen/p/4057996.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!