mybatis的selectKey作用詳解
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)orderAFTER
表示 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)之順序表篇
順序表,全名順序存儲(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-01Spring實(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ù)的詳解
本篇文章是對(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)用原理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10kafka消費(fèi)不到數(shù)據(jù)的排查過程
這篇文章主要介紹了kafka消費(fèi)不到數(shù)據(jù)的排查過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02Java行為型設(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-11SpringBoot結(jié)合Quartz實(shí)現(xiàn)數(shù)據(jù)庫存儲(chǔ)
本文主要介紹了SpringBoot+Quartz+數(shù)據(jù)庫存儲(chǔ),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01