插入一条记录并获取自增的id
2014-10-28 21:34
253 查看
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,更不要中途关闭连接!!!
相关文章推荐
- sql中插入一条记录并获取该条记录的自动增长ID
- 如何插入一条记录获取插入后的自动增长ID列的方法.
- 数据库中插入一条记录后获取主键id
- SQL 获取插入后的最新一条记录ID号
- jdbc插入一条记录后,马上获取到当前记录的id,以方便对插入的当前记录进行更多的操作
- 如何插入一条记录获取插入后的自动增长ID列的方法.
- hibernate中获取使用mysql当前插入一条记录的id值
- 获取最后插入的一条记录,使用函数scope_indentity()
- 怎样在插入一条记录的同时,立即返回刚插入如记录的ID值
- asp.net 获取插入记录的ID
- mysql中插入一条记录返回该记录id
- 获取新插入的记录ID
- 在插入一条记录后 取得自动增长ID
- 插入一条记录后,马上得到新插入记录ID值的方法
- ASP获取刚插入记录的自动编号ID
- asp.net 获取插入记录的ID
- MySQL中如何获取下一条插入的自增ID
- 插入一条记录后,如何得到主键ID号
- 插入数据后, 获取该记录id的方法
- ASP.NET Tips: 获取插入记录的ID