MySQL擷取Auto_increment欄位剛插入的值

來源:互聯網
上載者:User

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的值。

這兩種方法都不是安全執行緒的!!!!!

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.