溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用java如何獲取insert數(shù)據(jù)的自增id

發(fā)布時(shí)間:2021-02-22 16:04:34 來(lái)源:億速云 閱讀:452 作者:Leah 欄目:編程語(yǔ)言

這篇文章將為大家詳細(xì)講解有關(guān)使用java如何獲取insert數(shù)據(jù)的自增id,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

Java可以用來(lái)干什么

Java主要應(yīng)用于:1. web開(kāi)發(fā);2. Android開(kāi)發(fā);3. 客戶端開(kāi)發(fā);4. 網(wǎng)頁(yè)開(kāi)發(fā);5. 企業(yè)級(jí)應(yīng)用開(kāi)發(fā);6. Java大數(shù)據(jù)開(kāi)發(fā);7.游戲開(kāi)發(fā)等。

1、在連接1中向A表插入一條記錄,A表包含一個(gè)auto_increment類型的字段。

2、在連接2中向A表再插入一條記錄。

3、結(jié)果:在連接1中執(zhí)行select LAST_INSERT_ID()得到的結(jié)果和連接2中執(zhí)行select LAST_INSERT_ID()的結(jié)果是不同的;而在兩個(gè)連接中執(zhí)行select max(id)的結(jié)果是相同的。

其實(shí)在MSSQL中SCOPE_IDENTITY()和IDENT_CURRENT()的區(qū)別和這里是類似的。使用SCOPE_IDENTITY()可以獲得插入某個(gè)IDENTITY字段的當(dāng)前會(huì)話的值,而使用IDENT_CURRENT()會(huì)獲得在某個(gè)IDENTITY字段上插入的最大值,而不區(qū)分不同的會(huì)話。

注:使用select last_insert_id()時(shí)要注意,當(dāng)一次插入多條記錄時(shí),只是獲得第一次插入的id值,務(wù)必注意!

當(dāng)然,我們還可以使用另一種更加便捷的方法:在JDBC追加記錄后,使用API獲得新追加記錄的主鍵值。

這個(gè)實(shí)現(xiàn)使用了Statement的getGeneratedKeys方法,
當(dāng)Statement追加了一條記錄后,可以直接調(diào)用getGeneratedKeys方法獲得新追加記錄的key。

測(cè)試程序如下:

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.Statement; 
public class GetGenerateKey { 
public static void main(String[] args) throws Exception { 
create(); 
} 
public static void create()throws Exception { 
System.setProperty("jdbc.drivers", "com.mysql.jdbc.Driver"); 
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbc", "root", ""); 
Statement st = conn.createStatement(); 
String sql = "insert into user (name, birthday, money) values ('beck', '1949-10-01', 60)"; 
st.executeUpdate(sql, Statement.RETURN_GENERATED_KEYS); 
ResultSet rs = st.getGeneratedKeys(); 
if (rs.next()) { 
int id = rs.getInt(1); 
System.out.println ("生成記錄的key為 :" + id); 
} 
st.close(); 
conn.close(); 
} 
}

程序運(yùn)行結(jié)果:

生成記錄的key為 :9

數(shù)據(jù)庫(kù)的記錄為:

1
+----+----------+------------+-------+
2
| id | name | birthday | money |
3
+----+----------+------------+-------+
4
| 9 | beck | 1949-10-01 | 60 |
5
+----+----------+------------+-------+

總結(jié):這個(gè)API方法提供的好處就是不用重新再執(zhí)行一次查詢獲得新記錄的key值。減少了工作量和服務(wù)器的負(fù)擔(dān)。

注意點(diǎn),在執(zhí)行executeUpdate方法的時(shí)候,要指定返回生成key的選項(xiàng)。

===========================================================

2種方法的java 代碼

Java代碼1

// 用這種方法能得到插入自增的id 很好用 
PreparedStatement pstmt = conn.prepareStatement(sql.toString(),PreparedStatement.RETURN_GENERATED_KEYS); 
for (int i = 0; i < pars.length; i++) { 
pstmt.setObject(i+1, pars[i]); 
} 
pstmt.executeUpdate(); 
long autoIncKeyFromApi = -1; 
ResultSet rs = pstmt.getGeneratedKeys(); 
if (rs.next()) { 
autoIncKeyFromApi = rs.getInt(1); 
} 
return autoIncKeyFromApi;

Java代碼2

qRunner.update(conn,sql.toString(),pars); 
Long zsysqID = (Long) qRunner.query(conn, "SELECT LAST_INSERT_ID()", new ScalarHandler(1));

關(guān)于使用java如何獲取insert數(shù)據(jù)的自增id就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI