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

Mybatis返回插入的主鍵問題解決方案

 更新時(shí)間:2020年09月22日 11:52:17   作者:手撕高達(dá)的村長  
這篇文章主要介紹了Mybatis返回插入的主鍵問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

MyBatis添加記錄后獲取主鍵ID,這是一個(gè)很常見的需求。這個(gè)需求有分為兩種情況:(1)添加單條記錄時(shí)獲取主鍵值;(2)獲取批量添加記錄時(shí)各記錄的主鍵值。

備注:MyBatis從3.3.1版本開始支持批量添加記錄并返回各記錄主鍵字段值。

1、添加單一記錄時(shí)返回主鍵ID(方法一)

此種方法主要思路是:使用<insert>標(biāo)簽或者@Insert注解的屬性:useGeneratedKeys、keyProperty、keyColumn。下面分別以xml映射器和注解映射器分別詳細(xì)闡述一下。

2、添加單一記錄時(shí)返回主鍵ID(方法二)

在上面方法一中,如何獲取自增的id呢,估計(jì)很多人還有點(diǎn)疑惑,其實(shí)原理很簡單:當(dāng)插入數(shù)據(jù)之后,mybatis再次查詢mysql數(shù)據(jù)庫,獲得了注解id,然后填充到person對象的id屬性的。

業(yè)務(wù)中,會(huì)遇到這樣的問題,就是感覺返回的主鍵,插入作為其他表的外鍵。

那么問題來了,如何去實(shí)現(xiàn),其實(shí)方法比較簡單,這里就是重點(diǎn)記錄下,會(huì)出現(xiàn)的誤區(qū)。

用自動(dòng)生成sql工具的話,加上下面這句話

<generatedKey column="id" sqlStatement="JDBC" identity="true" />

生成的sql文件就會(huì)帶 useGeneratedKeys="true" keyProperty="travelId" 屬性。

首先,sql文件里面的需要加上兩個(gè)屬性。

<insert id="insertSelective" parameterType="com.sun.dto.HTRAVEL" useGeneratedKeys="true" keyProperty="travelId" ></insert>

  • useGeneratedKeys="true" 表示給主鍵設(shè)置自增長
  • keyProperty="userId" 表示將自增長后的Id賦值給實(shí)體類中的userId字段。
  • parameterType="com.chenzhou.mybatis.User" 這個(gè)屬性指向傳遞的參數(shù)實(shí)體類

然后接收的地方:
注意了,這里主鍵Id是不會(huì)在,返回值里面的。

而是在參數(shù)里面取。

int insertSelective(HTRAVEL record);
//這里才是本次插入的主鍵Id
record.getId();

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

相關(guān)文章

  • @Autowired 自動(dòng)注入接口失敗的原因及解決

    @Autowired 自動(dòng)注入接口失敗的原因及解決

    這篇文章主要介紹了@Autowired 自動(dòng)注入接口失敗的原因及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • mybatisplus的連表增強(qiáng)插件mybatis plus join

    mybatisplus的連表增強(qiáng)插件mybatis plus join

    本文主要介紹了mybatisplus的連表增強(qiáng)插件mybatis plus join,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Java正則表達(dá)式匹配字符串并提取中間值的方法實(shí)例

    Java正則表達(dá)式匹配字符串并提取中間值的方法實(shí)例

    正則表達(dá)式常用于字符串處理、表單驗(yàn)證等場合,實(shí)用高效,下面這篇文章主要給大家介紹了關(guān)于Java正則表達(dá)式匹配字符串并提取中間值的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Spring框架事務(wù)屬性中事務(wù)隔離級別與傳播行為全面講解

    Spring框架事務(wù)屬性中事務(wù)隔離級別與傳播行為全面講解

    這篇文章主要介紹了Spring框架聲明式事務(wù)的事務(wù)隔離級別和事務(wù)傳播行為,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • Java?SE之了解泛型

    Java?SE之了解泛型

    這篇文章主要介紹了Java?SE之了解泛型,文章內(nèi)容詳細(xì),簡單易懂,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2023-01-01
  • Java超詳細(xì)大文件分片上傳代碼

    Java超詳細(xì)大文件分片上傳代碼

    文件上傳是一個(gè)很常見的功能。在項(xiàng)目開發(fā)過程中,我們通常都會(huì)使用一些成熟的上傳組件來實(shí)現(xiàn)對應(yīng)的功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-06-06
  • Java獲取控制臺(tái)輸入的兩種方法小結(jié)

    Java獲取控制臺(tái)輸入的兩種方法小結(jié)

    這篇文章主要介紹了Java獲取控制臺(tái)輸入的兩種方法小結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 如何基于ssm框架實(shí)現(xiàn)springmvc攔截器

    如何基于ssm框架實(shí)現(xiàn)springmvc攔截器

    這篇文章主要介紹了如何基于ssm框架實(shí)現(xiàn)springmvc攔截器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • MyBatis中獲取Mysql數(shù)據(jù)庫插入記錄的主鍵值的實(shí)現(xiàn)

    MyBatis中獲取Mysql數(shù)據(jù)庫插入記錄的主鍵值的實(shí)現(xiàn)

    本文主要介紹了MyBatis中獲取Mysql數(shù)據(jù)庫插入記錄的主鍵值的實(shí)現(xiàn),包含了三種實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • 使用JPA插入枚舉類型字段

    使用JPA插入枚舉類型字段

    這篇文章主要介紹了使用JPA插入枚舉類型字段,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06

最新評論