日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JDBC 获取被插入数据的主键ID值

發(fā)布時(shí)間:2025/3/8 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JDBC 获取被插入数据的主键ID值 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

除了用存儲(chǔ)過程還有以下方法可以獲取:

?

?

static int create() throws SQLException {
??? Connection conn = null;
??? PreparedStatement ps = null;
??? ResultSet rs = null;
??? try {
??????? // 2.建立連接
??????? conn = JdbcUtils.getConnection();
??????? // conn = JdbcUtilsSing.getInstance().getConnection();
??????? // 3.創(chuàng)建語句
??????? String sql = "insert into user(name,birthday, money) values ('name2 gk', '1987-01-01', 400) ";
??????? ps = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);//參數(shù)2最好寫上,雖然Mysql不寫也能獲取但是不代表別的數(shù)據(jù)庫可以做到
??????? ps.executeUpdate();

??????? rs = ps.getGeneratedKeys();
??????? int id = 0;
??????? if (rs.next())
??????????? id = rs.getInt(1);
??????? return id;
??? } finally {
??????? JdbcUtils.free(rs, ps, conn);
??? }
}

?

?

?


getGeneratedKeys
ResultSet getGeneratedKeys()throws SQLException
獲取由于執(zhí)行此 Statement 對(duì)象而創(chuàng)建的所有自動(dòng)生成的鍵。如果此 Statement 對(duì)象沒有生成任何鍵,則返回空的 ResultSet 對(duì)象。

注:如果未指定表示自動(dòng)生成鍵的列,則 JDBC 驅(qū)動(dòng)程序?qū)崿F(xiàn)將確定最能表示自動(dòng)生成鍵的列。

返回:
包含通過執(zhí)行此 Statement 對(duì)象自動(dòng)生成的鍵的 ResultSet 對(duì)象
拋出:
SQLException - 如果發(fā)生數(shù)據(jù)庫訪問錯(cuò)誤,或者在已關(guān)閉的 Statement 上調(diào)用此方法
SQLFeatureNotSupportedException - 如果 JDBC 驅(qū)動(dòng)程序不支持此方法
從以下版本開始:
1.4

總結(jié)

以上是生活随笔為你收集整理的JDBC 获取被插入数据的主键ID值的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。