MySQL擷取Auto_increment欄位剛插入的值
不能使用select max(id) from testnotnull;
這樣來擷取剛插入的那個遞增欄位的值,
這樣沒有考慮多線程。
一個比較好的方法是:
使用java.sql.PreparedStatement pstmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
在插入資料之後,即執行pstmt.executeUpdate()後,
ResultSet rs = pstmt.getGeneratedKeys(); 擷取剛插入的那個自動自增欄位的值。
測試代碼:
@Test<br />public void testNextValue() {<br />try {<br />String MySQL = "jdbc:mysql://localhost/hibernate";<br />Class.forName("com.mysql.jdbc.Driver");<br />java.sql.Connection conn = DriverManager.getConnection(MySQL, "root", "root");<br />String sql = "insert into testnotnull values(null, ?, ?)";<br />java.sql.PreparedStatement pstmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);<br />conn.setAutoCommit(false);<br />int i = 1;<br />pstmt.setInt(i++, 234);<br />pstmt.setString(i++, "sdfsdf");<br />pstmt.executeUpdate();<br />ResultSet rs = pstmt.getGeneratedKeys();<br />System.out.println("The value is ");<br />if(rs.next()) {<br />System.out.println(rs.getInt(1));<br />}<br />conn.commit();<br />conn.setAutoCommit(true);<br />} catch (Exception e) {<br />e.printStackTrace();<br />} finally {<br />//do close....<br />}<br />}
如果只是單純的想要擷取Auto_increment的最大值,可用
select max(id) from testnotnull;
或 show table status from hibernate like 'testnotnull';擷取其中的Auto_increment的值。
這兩種方法都不是安全執行緒的!!!!!