欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解mysql插入數(shù)據(jù)后返回自增ID的七種方法

 更新時間:2020年12月28日 11:09:21   作者:一招鮮@Q  
這篇文章主要介紹了詳解mysql插入數(shù)據(jù)后返回自增ID的七種方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

引言

mysql 和 oracle 插入的時候有一個很大的區(qū)別是:

  • oracle 支持序列做 id;
  • mysql 本身有一個列可以做自增長字段。

mysql 在插入一條數(shù)據(jù)后,如何能獲得到這個自增 id 的值呢?

一:使用 last_insert_id()

SELECT LAST_INSERT_ID();

   1. 每次 mysql 的 query 操作在 mysql 服務(wù)器上可以理解為一次“原子”操作, 寫操作常常需要鎖表, 這里的鎖表是 mysql 應(yīng)用服務(wù)器鎖表不是我們的應(yīng)用程序鎖表。

   2. 因為 LAST_INSERT_ID 是基于 Connection 的,只要每個線程都使用獨立的 Connection 對象,LAST_INSERT_ID 函數(shù) 將返回該 Connection 對 AUTO_INCREMENT列 最新的 insert or update* 作生成的第一個 record 的ID。這個值不能被其它客戶端(Connection)影響,保證了你能夠找回自己的 ID 而不用擔(dān)心其它客戶端的活動,而且不需要加鎖。使用單INSERT 語句插入多條記錄,  LAST_INSERT_ID 返回一個列表。
   3. LAST_INSERT_ID 是與 table 無關(guān)的,如果向表 a 插入數(shù)據(jù)后,再向表 b 插入數(shù)據(jù),LAST_INSERT_ID 會改變。

二:使用 max(id)

如果不是頻繁的插入我們也可以使用這種方法來獲取返回的id值

select max(id) from user;

這個方法的缺點是不適合高并發(fā)。如果同時插入的時候返回的值可能不準(zhǔn)確。

三:創(chuàng)建一個存儲過程

在存儲過程中調(diào)用先插入再獲取最大值的操作。

DELIMITER $$
DROP PROCEDURE IF EXISTS `test` $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(in name varchar(100),out oid int)
BEGIN
 insert into user(loginname) values(name);
 select max(id) from user into oid;
 select oid;
END $$
DELIMITER ;
call test('gg',@id);

四:使用 @@identity

select @@IDENTITY

    @@identity 是表示的是最近一次向具有 identity 屬性(即自增列)的表插入數(shù)據(jù)時對應(yīng)的自增列的值,是系統(tǒng)定 義的全局變量。一般系統(tǒng)定義的全局變量都是以@@開頭,用戶自定義變量以@開頭。比如有個表 A,它的自增列是 id,當(dāng)向 A 表插入一行數(shù)據(jù)后,如果插入數(shù)據(jù) 后自增列的值自動增加至 101,則通過select @@identity得到的值就是 101。使用@@identity的前提是在進行 insert 操作后,執(zhí)行 select @@identity 的時候連接沒有關(guān)閉,否則得到的將是 NULL 值。

五:是使用 getGeneratedKeys()

Connection conn = ;
Serializable ret = null;
PreparedStatement state = .;
ResultSet rs=null;
try {
  state.executeUpdate();
  rs = state.getGeneratedKeys();
  if (rs.next()) {
    ret = (Serializable) rs.getObject(1);
  }   
} catch (SQLException e) {
}
return ret;

總結(jié):在 mysql 中做完插入之后獲取 id 在高并發(fā)的時候是很容易出錯的。另外 last_insert_id 雖然是基于 session 的但是不知道為什么沒有測試成功。    

六:selectkey:

其實在 ibtias 框架里使用 selectkey 這個節(jié)點,并設(shè)置 insert 返回值的類型為 integer,就可以返回這個 id 值。

SelectKey 在Mybatis中是為了解決 Insert 數(shù)據(jù)時不支持主鍵自動生成的問題,他可以很隨意的設(shè)置生成主鍵的方式。

不管 SelectKey 有多好,盡量不要遇到這種情況吧,畢竟很麻煩。

SelectKey 需要注意 order 屬性:

  • Mysql 一類支持自動增長類型的數(shù)據(jù)庫中,order 需要設(shè)置為 after 才會取到正確的值。
  • Oracle 這樣取序列的情況,需要設(shè)置為 before,否則會報錯。

xml 的例子:

<insert id="insert" parameterType="map"> 
  insert into table1 (name) values (#{name}) 
  <selectKey resultType="java.lang.Integer" keyProperty="id"> 
   SELECT LAST_INSERT_ID() AS id 
  </selectKey> 
</insert>

上面 xml 的傳入?yún)?shù)是 map,selectKey 會將結(jié)果放到入?yún)?shù) map 中。用 POJO 的情況一樣,但是有一點需要注意的是,keyProperty 對應(yīng)的字段在 POJO 中必須有相應(yīng)的 setter 方法,setter 的參數(shù)類型還要一致,否則會報錯。

注解的形式:

@Insert("insert into table2 (name) values(#{name})") 
@SelectKey(statement="call identity()", keyProperty="nameId", before=false, resultType=int.class) 
int insertTable2(Name name); 

方法七:使用<insert 中的useGeneratedKeys 和 keyProperty 兩個屬性

1.在Mybatis Mapper文件中添加屬性 “useGeneratedKeys”和“keyProperty”,其中 keyProperty 是 Java 對象的屬性名,而不是表格的字段名。

<insert id="insert" parameterType="Spares"   
    useGeneratedKeys="true" keyProperty="id">  
    insert into system(name) values(#{name})  
</insert> 

2.Mybatis 執(zhí)行完插入語句后,自動將自增長值賦值給對象 systemBean 的屬性id。因此,可通過 systemBean 對應(yīng)的 getter 方法獲?。?/p>

int count = systemService.insert(systemBean);  
int id = systemBean.getId(); //獲取到的即為新插入記錄的ID 

【注意事項】

1.Mybatis Mapper 文件中,“useGeneratedKeys” 和 “keyProperty” 必須添加,而且 keyProperty 一定得和 java 對象的屬性名稱一直,而不是表格的字段名。

2. java Dao中的 Insert 方法,傳遞的參數(shù)必須為 java 對象,也就是 Bean,而不能是某個參數(shù)。

到此這篇關(guān)于詳解mysql插入數(shù)據(jù)后返回自增ID的七種方法的文章就介紹到這了,更多相關(guān)mysql插入返回自增ID內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 將JavaDoc注釋生成API文檔的操作

    將JavaDoc注釋生成API文檔的操作

    這篇文章主要介紹了將JavaDoc注釋生成API文檔的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 為什么ConcurrentHashMap的key value不能為null,map可以?

    為什么ConcurrentHashMap的key value不能為null,map可以?

    這篇文章主要介紹了為什么ConcurrentHashMap的key value不能為null,map可以呢?具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Springboot?Vue實現(xiàn)單點登陸功能示例詳解

    Springboot?Vue實現(xiàn)單點登陸功能示例詳解

    這篇文章主要為大家介紹了Springboot?Vue實現(xiàn)單點登陸功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • IDEA配置Tomcat后,控制臺tomcat?catalina?log出現(xiàn)亂碼問題

    IDEA配置Tomcat后,控制臺tomcat?catalina?log出現(xiàn)亂碼問題

    本文介紹了如何通過設(shè)置Tomcat和IDEA的編碼格式來解決編碼問題,首先嘗試修改Tomcat的logging.properties文件中的編碼設(shè)置,如果未解決問題,則調(diào)整IDEA的編碼設(shè)置,通過修改vmoptions文件來全局設(shè)置IDEA的編碼格式,作者分享了個人成功解決問題的方法和步驟,供其他開發(fā)者參考
    2024-09-09
  • Java簡單數(shù)組排序(冒泡法)

    Java簡單數(shù)組排序(冒泡法)

    這篇文章主要介紹了Java簡單數(shù)組排序,實例分析了基于冒泡法實現(xiàn)數(shù)組排序的相關(guān)技巧,簡單實用,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • Java?Stream流中的filter()使用方法舉例詳解

    Java?Stream流中的filter()使用方法舉例詳解

    filter()是Java?Stream?API中的中間操作,用于根據(jù)給定的Predicate條件篩選流中的元素,它通過接收一個返回boolean值的函數(shù)(斷言)作為參數(shù),篩選出滿足條件的元素并收集到新的流中,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-11-11
  • springboot 2.0 mybatis mapper-locations掃描多個路徑的實現(xiàn)

    springboot 2.0 mybatis mapper-locations掃描多個路徑的實現(xiàn)

    這篇文章主要介紹了springboot 2.0 mybatis mapper-locations掃描多個路徑的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Swing常用組件之文本框和文本區(qū)

    Swing常用組件之文本框和文本區(qū)

    這篇文章主要為大家詳細介紹了Swing常用組件之文本框(JTestField)和文本區(qū)(JTextArea),Swing是一個用于開發(fā)Java應(yīng)用程序用戶界面的開發(fā)工具包,本文開始帶大家學(xué)習(xí)Swing
    2016-05-05
  • Java源碼解析之HashMap的put、resize方法詳解

    Java源碼解析之HashMap的put、resize方法詳解

    這篇文章主要介紹了Java源碼解析之HashMap的put、resize方法詳解,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有很大的幫助,需要的朋友可以參考下
    2021-04-04
  • IDEA安裝阿里代碼規(guī)范插件的步驟圖文詳解

    IDEA安裝阿里代碼規(guī)范插件的步驟圖文詳解

    這篇文章主要介紹了IDEA安裝阿里代碼規(guī)范插件的步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12

最新評論