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

詳解MyBatis中主鍵回填的兩種實(shí)現(xiàn)方式

 更新時(shí)間:2019年04月24日 09:29:47   作者:江南一點(diǎn)雨  
這篇文章主要介紹了詳解MyBatis中主鍵回填的兩種實(shí)現(xiàn)方式,主鍵回填其實(shí)是一個(gè)非常常見的需求,特別是在數(shù)據(jù)添加的過(guò)程中,我們經(jīng)常需要添加完數(shù)據(jù)之后,需要獲取剛剛添加的數(shù)據(jù) id,有興趣的可以參考一下

主鍵回填其實(shí)是一個(gè)非常常見的需求,特別是在數(shù)據(jù)添加的過(guò)程中,我們經(jīng)常需要添加完數(shù)據(jù)之后,需要獲取剛剛添加的數(shù)據(jù) id,無(wú)論是 Jdbc 還是各種各樣的數(shù)據(jù)庫(kù)框架都對(duì)此提供了相關(guān)的支持,本文我就來(lái)和和大家分享下數(shù)據(jù)庫(kù)主鍵回填在 MyBatis 中的兩種實(shí)現(xiàn)思路。

原生寫法

框架來(lái)源于我們學(xué)過(guò)的基礎(chǔ)知識(shí),主鍵回填實(shí)際上是一個(gè)在 JDBC 中就被支持的寫法,有的小伙伴可能不知道這一點(diǎn),因此這里我先來(lái)說(shuō)說(shuō)在 JDBC 中如何實(shí)現(xiàn)主鍵回填。

JDBC 中實(shí)現(xiàn)主鍵回填其實(shí)非常容易,主要是在構(gòu)造 PreparedStatement 時(shí)指定需要主鍵回填,然后在插入成功后,查詢剛剛插入數(shù)據(jù)的 id ,示例代碼如下:

public int insert(Person person) {
  Connection con = null;
  PreparedStatement ps = null;
  ResultSet rs = null;
  con = DBUtils.getConnection();
  ps = con.prepareStatement("INSERT INTO person(username,password,money) VALUES(?,?,?)", PreparedStatement.RETURN_GENERATED_KEYS);
  ps.setObject(1, person.getUsername());
  ps.setObject(2, person.getPassword());
  ps.setObject(3, person.getMoney());
  int i = ps.executeUpdate();
  rs = ps.getGeneratedKeys();
  int id = -1;
  if (rs.next()) {
    id = rs.getInt(1);
  }
  return id;
}

和普通的插入 SQL 不同之處主要體現(xiàn)在兩個(gè)地方:

  • 第一個(gè)是構(gòu)造 PreparedStatement 時(shí),多了一個(gè)參數(shù),指定了需要主鍵回填。
  • 在更新操作執(zhí)行完成之后,調(diào)用 getGeneratedKeys ,然后又會(huì)獲取到一個(gè) ResultSet 對(duì)象,從這個(gè)游標(biāo)集中就可以獲取到剛剛插入數(shù)據(jù)的id。

這個(gè)是原生的寫法,在 MyBatis 中,對(duì)此需求提供了兩種不同的實(shí)現(xiàn)方案,下面分別來(lái)看。

框架寫法

一般情況下,主鍵有兩種生成方式:

  1. 主鍵自增長(zhǎng)
  2. 自定義主鍵(一般可以使用UUID,或者類UUID)

如果是第二種,主鍵一般是在Java代碼中生成,然后傳入數(shù)據(jù)庫(kù)執(zhí)行插入操作,如果是第一個(gè)主鍵自增長(zhǎng),此時(shí),Java 可能需要知道數(shù)據(jù)添加成功后的主鍵。

MyBatis 的基本用法就無(wú)需多說(shuō)了,這也不是本文的重點(diǎn),我們還是來(lái)看看 MyBatis 中主鍵回填的兩種不同實(shí)現(xiàn)方式吧!

方式一

第一種方式比較簡(jiǎn)單,也是松哥推薦的一種實(shí)現(xiàn)方式:

<insert id="insertBook" useGeneratedKeys="true" keyProperty="id">
  insert into t_book (b_name,author) values (#{name},#{author});
</insert>

這種方式比較簡(jiǎn)單,就是在插入節(jié)點(diǎn)上添加 useGeneratedKeys 屬性,同時(shí)設(shè)置接收回傳主鍵的屬性。配置完成后,我們執(zhí)行一個(gè)插入操作,插入時(shí)傳入一個(gè)對(duì)象,插入完成后,這個(gè)對(duì)象的 id 就會(huì)被自動(dòng)賦值,值就是剛剛插入成功的id。

推薦大家使用這種方式,原因很簡(jiǎn)單,這種方式實(shí)現(xiàn)簡(jiǎn)便省事。

方式二

第二種方式則是利用MySQL自帶的 last_insert_id() 函數(shù)查詢剛剛插入的id,示例代碼如下:

<insert id="insertBook">
  <selectKey keyProperty="id" resultType="java.lang.Integer">
    SELECT LAST_INSERT_ID()
  </selectKey>
  insert into t_book (b_name,author) values (#{name},#{author});
</insert>

這種方式是在 insert 節(jié)點(diǎn)中添加 selectKey 來(lái)實(shí)現(xiàn)主鍵回填,實(shí)際上這種方式的功能更加豐富,因?yàn)?selectKey 節(jié)點(diǎn)中的 SQL 我們既可以在插入之前執(zhí)行,也可以在插入之后執(zhí)行(通過(guò)設(shè)置節(jié)點(diǎn)的 Order 屬性為 AFTER 或者 BEFORE 可以實(shí)現(xiàn)),具體什么時(shí)候執(zhí)行,還是要看具體的需求,如果是做主鍵回填,我們當(dāng)然需要在插入 SQL 執(zhí)行之后執(zhí)行 selectKey 節(jié)點(diǎn)中的 SQL。

注意第二種方式一樣也要通過(guò)設(shè)置 keyProperty 來(lái)指定將查詢到的數(shù)據(jù)綁定到哪個(gè)屬性上。

總結(jié)

好了,本文向大家介紹了 MyBatis 中主鍵回填的兩種方式,大家有沒有 get 到呢?有問題歡迎留言討論。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JAVA基礎(chǔ)之繼承(inheritance)詳解

    JAVA基礎(chǔ)之繼承(inheritance)詳解

    繼承(inheritance)是Java OOP中一個(gè)非常重要的概念。這篇文章主要介紹了JAVA基礎(chǔ)之繼承(inheritance),需要的朋友可以參考下
    2017-03-03
  • Spring Security實(shí)現(xiàn)動(dòng)態(tài)路由權(quán)限控制方式

    Spring Security實(shí)現(xiàn)動(dòng)態(tài)路由權(quán)限控制方式

    這篇文章主要介紹了Spring Security實(shí)現(xiàn)動(dòng)態(tài)路由權(quán)限控制方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • java中數(shù)組的定義及使用方法(推薦)

    java中數(shù)組的定義及使用方法(推薦)

    下面小編就為大家?guī)?lái)一篇java中數(shù)組的定義及使用方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-07-07
  • Java正則判斷日期格式是否正確的方法示例

    Java正則判斷日期格式是否正確的方法示例

    這篇文章主要介紹了Java正則判斷日期格式是否正確的方法,結(jié)合實(shí)例形式分析了Java針對(duì)日期字符串正則判斷的相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03
  • 二叉樹基本操作之遞歸和非遞歸遍歷、分支節(jié)點(diǎn)數(shù)詳解

    二叉樹基本操作之遞歸和非遞歸遍歷、分支節(jié)點(diǎn)數(shù)詳解

    這篇文章主要介紹了二叉樹基本操作之遞歸和非遞歸遍歷、分支節(jié)點(diǎn)數(shù)詳解,二叉樹是由n(n>=0)個(gè)結(jié)點(diǎn)的有限集合構(gòu)成,此集合或者為空集,或者由一個(gè)根結(jié)點(diǎn)及兩棵互不相交的左右子樹組成,并且左右子樹都是二叉樹,需要的朋友可以參考下
    2023-09-09
  • Java 過(guò)濾器實(shí)現(xiàn)敏感詞匯過(guò)濾功能

    Java 過(guò)濾器實(shí)現(xiàn)敏感詞匯過(guò)濾功能

    通過(guò)使用 Java 過(guò)濾器,我們可以輕松地實(shí)現(xiàn)敏感詞匯過(guò)濾的功能,以保護(hù)用戶免受不良內(nèi)容的侵害,讓我們通過(guò)一個(gè)簡(jiǎn)單的示例來(lái)演示我們的敏感詞匯過(guò)濾器是如何工作的,感興趣的朋友一起看看吧
    2024-01-01
  • java反射方式創(chuàng)建代碼詳解

    java反射方式創(chuàng)建代碼詳解

    在本篇文章里小編給大家整理的是一篇關(guān)于java反射方式創(chuàng)建代碼詳解內(nèi)容,對(duì)此有興趣的朋友們可以學(xué)習(xí)下。
    2021-01-01
  • mybatis-plus中的Enum用法實(shí)例

    mybatis-plus中的Enum用法實(shí)例

    本文主要介紹了mybatis-plus中的Enum用法實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Java單線程ThreadLocal串值問題解決方案

    Java單線程ThreadLocal串值問題解決方案

    這篇文章主要介紹了Java單線程ThreadLocal串值問題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Spring?Cloud?OpenFeign模版化客戶端搭建過(guò)程

    Spring?Cloud?OpenFeign模版化客戶端搭建過(guò)程

    OpenFeign是一個(gè)顯示聲明式的WebService客戶端。使用OpenFeign能讓編寫Web Service客戶端更加簡(jiǎn)單,這篇文章主要介紹了Spring?Cloud?OpenFeign模版化客戶端,需要的朋友可以參考下
    2022-06-06

最新評(píng)論