mybatis的selectKey作用詳解
mybatis的selectKey作用
當我們使用id自增操作Mybatis時,需要返回最新插入的id的話,可以進行如下操作:
<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
對應的實體類中的主鍵的屬性名,這里是 實體類中的id,因為它跟數(shù)據(jù)庫的主鍵對應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>
當使用了selectkey時 Dao接口請勿使用@Param 映射注解,會導致selectKey標簽失效
int insertCheckGroup(CheckGroup checkGroup);
如果傳多個參數(shù)需使用@Param時
int insertCheckGroup(@Param("test") CheckGroup checkGroup);
xml標簽keyProperty對應主鍵名稱時應加上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)之順序表篇
順序表,全名順序存儲結(jié)構(gòu),是線性表的一種。線性表用于存儲邏輯關(guān)系為“一對一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對數(shù)據(jù)物理存儲結(jié)構(gòu)也有要求。順序表存儲數(shù)據(jù)時,會提前申請一整塊足夠大小的物理空間,然后將數(shù)據(jù)依次存儲起來,存儲時數(shù)據(jù)元素間不留縫隙2022-01-01Spring實戰(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ù)進行了詳細的分析介紹,需要的朋友參考下2013-06-06詳解MyBatis Mapper 代理實現(xiàn)數(shù)據(jù)庫調(diào)用原理
這篇文章主要介紹了詳解MyBatis Mapper 代理實現(xiàn)數(shù)據(jù)庫調(diào)用原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10Java行為型設(shè)計模式之外觀設(shè)計模式詳解
外觀模式為多個復雜的子系統(tǒng),提供了一個一致的界面,使得調(diào)用端只和這個接口發(fā)生調(diào)用,而無須關(guān)系這個子系統(tǒng)內(nèi)部的細節(jié)。本文將通過示例詳細為大家講解一下外觀模式,需要的可以參考一下2022-11-11SpringBoot結(jié)合Quartz實現(xiàn)數(shù)據(jù)庫存儲
本文主要介紹了SpringBoot+Quartz+數(shù)據(jù)庫存儲,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01