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

mybatis的selectKey作用詳解

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

mybatis的selectKey作用

當(dāng)我們使用id自增操作Mybatis時,需要返回最新插入的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 會將 SELECT LAST_INSERT_ID()的結(jié)果放入到傳入的實體類的主鍵里面,
  • keyProperty對應(yīng)的實體類中的主鍵的屬性名,這里是 實體類中的id,因為它跟數(shù)據(jù)庫的主鍵對應(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時 Dao接口請勿使用@Param 映射注解,會導(dǎo)致selectKey標(biāo)簽失效

int insertCheckGroup(CheckGroup checkGroup);

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

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

xml標(biāo)簽keyProperty對應(yīng)主鍵名稱時應(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>

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評論