亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis中selectKey有什么用

發布時間:2022-01-25 10:44:43 來源:億速云 閱讀:303 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關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()的結果放入到傳入的實體類的主鍵里面,

  • keyProperty對應的實體類中的主鍵的屬性名,這里是 實體類中的id,因為它跟數據庫的主鍵對應order

  • AFTER 表示 SELECT LAST_INSERT_ID() 在insert執行之后執行,多用與自增主鍵,

  • BEFORE 表示 SELECTLAST_INSERT_ID() 在insert執行之前執行,這樣的話就拿不到主鍵了,這種適合那種主鍵不是自增的類型

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);

如果傳多個參數需使用@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>

感謝各位的閱讀!關于“mybatis中selectKey有什么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

遂溪县| 宜宾县| 龙井市| 杭锦后旗| 克什克腾旗| 莫力| 石城县| 新巴尔虎左旗| 克山县| 四会市| 石河子市| 韶山市| 容城县| 宁波市| 井冈山市| 金川县| 荃湾区| 朝阳区| 抚远县| 宝山区| 沂水县| 海门市| 日照市| 浑源县| 巴马| 隆子县| 崇左市| 山东省| 鞍山市| 敦煌市| 拉孜县| 云霄县| 高陵县| 洪江市| 博客| 潢川县| 灯塔市| 江孜县| 大安市| 吴忠市| 呼和浩特市|