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

mybatis的selectKey作用詳解

 更新時(shí)間:2022年01月25日 08:43:38   作者:Chandler丶  
這篇文章主要介紹了mybatis的selectKey作用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。</P><P>

mybatis的selectKey作用

當(dāng)我們使用id自增操作Mybatis時(shí),需要返回最新插入的id的話,可以進(jìn)行如下操作:

<selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="id">
SELECT LAST_INSERT_ID() AS ID?
</selectKey>?

在insert中添加即可:

<insert id="insert" parameterType="com.pinyougou.pojo.TbGoods" >
? ? <selectKey resultType="java.lang.Long" order="AFTER" keyProperty="id">
? ? ? SELECT LAST_INSERT_ID() AS id
? ? </selectKey>
? ? insert into tb_goods (id, seller_id, goods_name,
? ? ? default_item_id, audit_status, is_marketable,?
? ? ? brand_id, caption, category1_id,?
? ? ? category2_id, category3_id, small_pic,?
? ? ? price, type_template_id, is_enable_spec,?
? ? ? is_delete)
? ? values (#{id,jdbcType=BIGINT}, #{sellerId,jdbcType=VARCHAR}, #{goodsName,jdbcType=VARCHAR},?
? ? ? #{defaultItemId,jdbcType=BIGINT}, #{auditStatus,jdbcType=VARCHAR}, #{isMarketable,jdbcType=VARCHAR},?
? ? ? #{brandId,jdbcType=BIGINT}, #{caption,jdbcType=VARCHAR}, #{category1Id,jdbcType=BIGINT},?
? ? ? #{category2Id,jdbcType=BIGINT}, #{category3Id,jdbcType=BIGINT}, #{smallPic,jdbcType=VARCHAR},?
? ? ? #{price,jdbcType=DECIMAL}, #{typeTemplateId,jdbcType=BIGINT}, #{isEnableSpec,jdbcType=VARCHAR},?
? ? ? #{isDelete,jdbcType=VARCHAR})
? </insert>

然后操作int newId = goodsMapper.insert(goods.getGoods()); 就能拿到最新加入的ID信息了 

mybatis selectKey 失效問題踩坑

  • selectKey 會(huì)將 SELECT LAST_INSERT_ID()的結(jié)果放入到傳入的實(shí)體類的主鍵里面,
  • keyProperty對(duì)應(yīng)的實(shí)體類中的主鍵的屬性名,這里是 實(shí)體類中的id,因?yàn)樗鷶?shù)據(jù)庫的主鍵對(duì)應(yīng)order
  • AFTER 表示 SELECT LAST_INSERT_ID() 在insert執(zhí)行之后執(zhí)行,多用與自增主鍵,
  • BEFORE 表示 SELECTLAST_INSERT_ID() 在insert執(zhí)行之前執(zhí)行,這樣的話就拿不到主鍵了,這種適合那種主鍵不是自增的類型

resultType 主鍵類型

<insert id="insertCheckGroup" ?parameterType="com.zyl.pojo.CheckGroup">
? ? ? ? <selectKey resultType="int" keyProperty="id" order="AFTER">
? ? ? ? ? ? SELECT LAST_INSERT_ID()
? ? ? ? </selectKey>
? ? ? ? insert into check_group (name) value (#{name});
</insert>

當(dāng)使用了selectkey時(shí) Dao接口請(qǐng)勿使用@Param 映射注解,會(huì)導(dǎo)致selectKey標(biāo)簽失效

int insertCheckGroup(CheckGroup checkGroup);

如果傳多個(gè)參數(shù)需使用@Param時(shí)

int insertCheckGroup(@Param("test") CheckGroup checkGroup);

xml標(biāo)簽keyProperty對(duì)應(yīng)主鍵名稱時(shí)應(yīng)加上test.

<insert id="insertCheckGroup" ?parameterType="com.zyl.pojo.CheckGroup">
? ? ? ? <selectKey resultType="int" keyProperty="test.id" order="AFTER">
? ? ? ? ? ? SELECT LAST_INSERT_ID()
? ? ? ? </selectKey>
? ? ? ? insert into check_group (name) value (#{name});
</insert>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java數(shù)據(jù)結(jié)構(gòu)之順序表篇

    Java數(shù)據(jù)結(jié)構(gòu)之順序表篇

    順序表,全名順序存儲(chǔ)結(jié)構(gòu),是線性表的一種。線性表用于存儲(chǔ)邏輯關(guān)系為“一對(duì)一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對(duì)數(shù)據(jù)物理存儲(chǔ)結(jié)構(gòu)也有要求。順序表存儲(chǔ)數(shù)據(jù)時(shí),會(huì)提前申請(qǐng)一整塊足夠大小的物理空間,然后將數(shù)據(jù)依次存儲(chǔ)起來,存儲(chǔ)時(shí)數(shù)據(jù)元素間不留縫隙
    2022-01-01
  • 詳解springboot中使用異步的常用兩種方式及其比較

    詳解springboot中使用異步的常用兩種方式及其比較

    這篇文章主要介紹了詳解springboot中使用異步的常用兩種方式及其比較,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Spring實(shí)戰(zhàn)之調(diào)用實(shí)例工廠方法創(chuàng)建Bean操作示例

    Spring實(shí)戰(zhàn)之調(diào)用實(shí)例工廠方法創(chuàng)建Bean操作示例

    這篇文章主要介紹了Spring實(shí)戰(zhàn)之調(diào)用實(shí)例工廠方法創(chuàng)建Bean操作,結(jié)合實(shí)例形式分析了實(shí)例工廠方法創(chuàng)建Bean相關(guān)配置、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-11-11
  • 探討:使用httpClient在客戶端與服務(wù)器端傳輸對(duì)象參數(shù)的詳解

    探討:使用httpClient在客戶端與服務(wù)器端傳輸對(duì)象參數(shù)的詳解

    本篇文章是對(duì)使用httpClient在客戶端與服務(wù)器端傳輸對(duì)象參數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 詳解MyBatis Mapper 代理實(shí)現(xiàn)數(shù)據(jù)庫調(diào)用原理

    詳解MyBatis Mapper 代理實(shí)現(xiàn)數(shù)據(jù)庫調(diào)用原理

    這篇文章主要介紹了詳解MyBatis Mapper 代理實(shí)現(xiàn)數(shù)據(jù)庫調(diào)用原理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • java環(huán)境變量配置和adb的配置教程詳解

    java環(huán)境變量配置和adb的配置教程詳解

    這篇文章主要介紹了java環(huán)境變量配置和adb的配置教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • java中關(guān)于Map的三種遍歷方法詳解

    java中關(guān)于Map的三種遍歷方法詳解

    本篇文章是對(duì)java中關(guān)于Map的三種遍歷方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • kafka消費(fèi)不到數(shù)據(jù)的排查過程

    kafka消費(fèi)不到數(shù)據(jù)的排查過程

    這篇文章主要介紹了kafka消費(fèi)不到數(shù)據(jù)的排查過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Java行為型設(shè)計(jì)模式之外觀設(shè)計(jì)模式詳解

    Java行為型設(shè)計(jì)模式之外觀設(shè)計(jì)模式詳解

    外觀模式為多個(gè)復(fù)雜的子系統(tǒng),提供了一個(gè)一致的界面,使得調(diào)用端只和這個(gè)接口發(fā)生調(diào)用,而無須關(guān)系這個(gè)子系統(tǒng)內(nèi)部的細(xì)節(jié)。本文將通過示例詳細(xì)為大家講解一下外觀模式,需要的可以參考一下
    2022-11-11
  • SpringBoot結(jié)合Quartz實(shí)現(xiàn)數(shù)據(jù)庫存儲(chǔ)

    SpringBoot結(jié)合Quartz實(shí)現(xiàn)數(shù)據(jù)庫存儲(chǔ)

    本文主要介紹了SpringBoot+Quartz+數(shù)據(jù)庫存儲(chǔ),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評(píng)論