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

MYSQL數(shù)據插入之返回自增主鍵ID的方法詳解

 更新時間:2023年10月08日 09:21:15   作者:童話ing  
這篇文章主要介紹了MYSQL數(shù)據插入之返回自增主鍵ID的方法詳解,mysql中的insert插入之后會有返回值,返回的是影響的行數(shù),也就是說,成功插入一條數(shù)據之后返回的是1,失敗則返回0,那么,很多時候我們都想要得到最后插入的id值,需要的朋友可以參考下

前言

我們都知道,mysql中的insert插入之后會有返回值,返回的是影響的行數(shù),也就是說,成功插入一條數(shù)據之后返回的是1,失敗則返回0。那么,很多時候我們都想要得到最后插入的id值,下面七種方法均可,結合場景使用。

MYSQL插入數(shù)據后返回自增ID的方法

mysql和oracle插入的時候有一個很大的區(qū)別是,oracle支持序列做id,mysql本身有一個列可以做自增長字段,mysql在插入一條數(shù)據后,如何能獲得到這個自增id的值呢?

1、使用last_insert_id

SELECT LAST_INSERT_ID();

  產生的ID 每次連接后保存在服務器中。這意味著函數(shù)向一個給定客戶端返回的值是該客戶端產生對影響AUTO_INCREMENT列的最新語句第一個 AUTO_INCREMENT值的。這個值不能被其它客戶端影響,即使它們產生它們自己的 AUTO_INCREMENT值。這個行為保證了你能夠找回自己的 ID 而不用擔心其它客戶端的活動,而且不需要加鎖或處理。 每次mysql_query操作在mysql服務器上可以理解為一次“原子”操作, 寫操作常常需要鎖表的, 是mysql應用服務器鎖表不是我們的應用程序鎖表。

值得注意的是,如果你一次插入了多條記錄,這個函數(shù)返回的是第一個記錄的ID值。

因為LAST_INSERT_ID是基于Connection的,只要每個線程都使用獨立的Connection對象,LAST_INSERT_ID函數(shù) 將返回該Connection對AUTO_INCREMENT列最新的insert or update*作生成的第一個record的ID。這個值不能被其它客戶端(Connection)影響,保證了你能夠找回自己的 ID 而不用擔心其它客戶端的活動,而且不需要加鎖。使用單INSERT語句插入多條記錄, LAST_INSERT_ID返回一個列表。

LAST_INSERT_ID 是與table無關的,如果向表a插入數(shù)據后,再向表b插入數(shù)據,LAST_INSERT_ID會改變。 所以我們可以使用下面方式:

<insert id="insert" parameterType="com.dl.blog.pojo.BlogTag">
    <selectKey resultType="integer" order="AFTER" keyProperty="id">
      SELECT LAST_INSERT_ID()
    </selectKey>
   insert into blog_tag (name)
   values  (#{name,jdbcType=VARCHAR})
</insert>

2、使用max(id)

使用last_insert_id是基礎連接的,如果換一個窗口的時候調用則會一直返回10 如果不是頻繁的插入我們也可以使用這種方法來獲取返回的id值

select max(id) from user;

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

3、獲取最大值

創(chuàng)建一個存儲過程,在存儲過程中調用先插入再獲取最大值的操作

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);

4、使用@@identity

select @@IDENTITY

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

5、使用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;

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

6、selectkey

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

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

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

selectKey Attributes

屬性描述
keyPropertyselectKey 語句結果應該被設置的目標屬性。
resultType結果的類型。MyBatis 通??梢运愠鰜?但是寫上也沒有問題。MyBatis 允許任何簡單類型用作主鍵的類型,包括字符串。
order這可以被設置為 BEFORE 或 AFTER。如果設置為 BEFORE,那么它會首先選擇主鍵,設置 keyProperty 然后執(zhí)行插入語句。如果設置為 AFTER,那么先執(zhí)行插入語句,然后是 selectKey 元素-這和如 Oracle 數(shù)據庫相似,可以在插入語句中嵌入序列調用。
statementType和前面的相 同,MyBatis 支持 STATEMENT ,PREPARED 和CALLABLE 語句的映射類型,分別代表 PreparedStatement 和CallableStatement 類型。

SelectKey需要注意order屬性,像Mysql一類支持自動增長類型的數(shù)據庫中,order需要設置為after才會取到正確的值。

像Oracle這樣取序列的情況,需要設置為before,否則會報錯。

另外在用Spring管理事務時,SelectKey和插入在同一事務當中,因而Mysql這樣的情況由于數(shù)據未插入到數(shù)據庫中,所以是得不到自動增長的Key。取消事務管理就不會有問題。 下面是一個xml和注解的例子,SelectKey很簡單,兩個例子就夠了:

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

上面xml的傳入參數(shù)是map,selectKey會將結果放到入參數(shù)map中。用POJO的情況一樣,但是有一點需要注意的是,keyProperty對應的字段在POJO中必須有相應的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); 

7、使用<insert中的useGeneratedKeys 和keyProperty 兩個屬性

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

  <insert id="insert" parameterType="com.dl.blog.pojo.BlogTag" useGeneratedKeys="true" keyProperty="id">
    insert into blog_tag (name)
    values  (#{name,jdbcType=VARCHAR})
  </insert>

然后我們在java代碼中Mybatis執(zhí)行完插入語句后,自動將自增長值賦值給對象systemBean的屬性id。因此,可通過systemBean對應的getter方法獲??!

int count=blogTagMapper.insert(blogTag);//返回的是影響記錄的行數(shù)
int id=blogTag.getId();//獲取到的即為新插入記錄的ID 

POJO實體類,省略getter、setter、和構造方法

public class BlogTag {
    private Integer id;
    private String name;
}

數(shù)據庫表結構:

在這里插入圖片描述

【注意事項】

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

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

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

相關文章

  • Mysql巧用join優(yōu)化sql的方法詳解

    Mysql巧用join優(yōu)化sql的方法詳解

    這篇文章主要給大家介紹了關于Mysql巧用join優(yōu)化sql的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Mysql具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • MySQL DELETE速度提高的幾種方法

    MySQL DELETE速度提高的幾種方法

    提高MySQL中DELETE操作的速度通常涉及多個方面,包括優(yōu)化查詢、索引、表結構、硬件和配置等,本文主要介紹了MySQL DELETE速度提高的幾種方法,感興趣的可以了解一下
    2024-07-07
  • 關于MySQL的時間進位問題淺析

    關于MySQL的時間進位問題淺析

    這篇文章主要給大家介紹了關于MySQL的時間進位問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • MYSQL基礎之連接MYSQL、修改密碼、添加用戶

    MYSQL基礎之連接MYSQL、修改密碼、添加用戶

    在這篇文章中我們就從連接MYSQL、修改密碼、增加用戶等方面來學習一些MYSQL的常用命令。
    2008-08-08
  • windows 環(huán)境下 MySQL 8.0.13 免安裝版配置教程

    windows 環(huán)境下 MySQL 8.0.13 免安裝版配置教程

    這篇文章主要介紹了windows 環(huán)境下 MySQL 8.0.13 免安裝版配置教程,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-12-12
  • MySql連接數(shù)據庫常用參數(shù)及代碼解讀

    MySql連接數(shù)據庫常用參數(shù)及代碼解讀

    這篇文章主要介紹了MySql連接數(shù)據庫常用參數(shù)及代碼解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • DELETE、TRUNCATE 和 DROP 在MySQL中的區(qū)別及功能使用示例

    DELETE、TRUNCATE 和 DROP 在MySQL中的區(qū)別及功能使用示例

    在MySQL數(shù)據庫中,DELETE、TRUNCATE TABLE 和 DROP 這三個命令分別適用于不同的數(shù)據刪除需求,它們在工作原理、應用場景以及特性上有所區(qū)別,這篇文章主要介紹了DELETE、TRUNCATE 和 DROP 在MySQL中的區(qū)別及功能使用示例,需要的朋友可以參考下
    2024-03-03
  • mysql中用于數(shù)據遷移存儲過程分享

    mysql中用于數(shù)據遷移存儲過程分享

    mysql 數(shù)據遷移用的一個存儲過程,需要的朋友可以收藏下。
    2011-05-05
  • MySQL 如何分析查詢性能

    MySQL 如何分析查詢性能

    這篇文章主要介紹了MySQL 如何分析查詢性能,幫助大家更好的理解和學習使用MySQL,感興趣的朋友可以了解下
    2021-05-05
  • 詳解Mysql之mysqlbackup備份與恢復實踐

    詳解Mysql之mysqlbackup備份與恢復實踐

    這篇文章主要介紹了詳解Mysql之mysqlbackup備份與恢復實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02

最新評論