MyBatis insert同时获取自增id

4 篇文章 0 订阅
1 篇文章 0 订阅

在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数;
如果业务层需要在插入数据的同时获取到自增主键的时候,可以采用以下方式

方法一、针对oracle数据库 Sequence主键的方式

<insert id="add" parameterType="com.LearnTrainDoc">
<selectKey keyProperty="id" resultType="java.lang.String" order="BEFORE">
select lp_learn_train_doc.nextval from dual
</selectKey>

  insert into lp_learn_train_doc (id, learn_catagory_code, learn_catagory_name,
    catagory_code, catagory_name, learn_doc_name,
    upload_user, upload_time, doc_status,
    remark, last_update)
    values (#{id,jdbcType=INTEGER}, #{learnCatagoryCode,jdbcType=VARCHAR}, #{learnCatagoryName,jdbcType=VARCHAR},
    #{catagoryCode,jdbcType=VARCHAR}, #{catagoryName,jdbcType=VARCHAR}, #{learnDocName,jdbcType=VARCHAR},
    #{uploadUser,jdbcType=VARCHAR}, #{uploadTime,jdbcType=TIMESTAMP}, #{docStatus,jdbcType=VARCHAR},
    #{remark,jdbcType=VARCHAR}, #{lastUpdate,jdbcType=TIMESTAMP})
 </insert>

方法二、针对mysql数据库 自增主键的方式

<insert id="save"
          useGeneratedKeys="true" keyColumn="id" keyProperty="id"
          parameterType="com.LearnTrainDoc" >
    insert into lp_learn_train_doc (id, learn_catagory_code, learn_catagory_name,
    catagory_code, catagory_name, learn_doc_name,
    upload_user, upload_time, doc_status,
    remark, last_update)
    values (#{id,jdbcType=INTEGER}, #{learnCatagoryCode,jdbcType=VARCHAR}, #{learnCatagoryName,jdbcType=VARCHAR},
    #{catagoryCode,jdbcType=VARCHAR}, #{catagoryName,jdbcType=VARCHAR}, #{learnDocName,jdbcType=VARCHAR},
    #{uploadUser,jdbcType=VARCHAR}, #{uploadTime,jdbcType=TIMESTAMP}, #{docStatus,jdbcType=VARCHAR},
    #{remark,jdbcType=VARCHAR}, #{lastUpdate,jdbcType=TIMESTAMP})

    <selectKey resultType="int" keyProperty="id" order="AFTER">
      SELECT LAST_INSERT_ID()
    </selectKey>
  </insert>

切记:不要把Mybatis的insert方法返回值当成主键!!! 这个返回是是影响行数。
获取主键的时候需要从对象的getId()方法获取,相当于Mybatis再做完insert动作后把id又set到model对象中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值