activiti启动流程的过程中BUSSINESS_KEY没有获取到key

在MyBatis中,若需获取自动生成的主键ID,需使用主键回填机制。原始XML映射文件的插入语句未包含这一机制,导致无法获取新插入记录的ID。通过在插入语句后添加`<selectKey>`标签并设置`keyProperty`为'id',可以实现主键回填,确保在实际开发中能够正确获取到新生成的ID。
摘要由CSDN通过智能技术生成

在这里插入图片描述

启动流程的时候没注意到这里是一个空值,在学习mybatis过程中我们知道mybatis是不能够获取自动生成的主键id的,而这里必须获取到id,所以需要用到一个主键回填机制
下面是mybatis自己生成的mapper.xml中的代码

<insert id="insert" parameterType="com.git.oa.pojo.Baoxiaobill" >
    insert into baoxiaobill (id, money, title, 
      remark, creatdate, state, 
      user_id)
    values (#{id,jdbcType=INTEGER}, #{money,jdbcType=DECIMAL}, #{title,jdbcType=VARCHAR}, 
      #{remark,jdbcType=VARCHAR}, #{creatdate,jdbcType=TIMESTAMP}, #{state,jdbcType=INTEGER}, 
      #{userId,jdbcType=INTEGER})
  </insert>

并没有主键回填,结果就会出现图片上那样的null,但是我们在实际开发过程中往往需要用到这个id,所以就需要一个主键回填的机制,修改后的代码块,添加了主键回填

<insert id="insert" parameterType="com.git.oa.pojo.Baoxiaobill" >
    insert into baoxiaobill (id, money, title, 
      remark, creatdate, state, 
      user_id)
    values (#{id,jdbcType=INTEGER}, #{money,jdbcType=DECIMAL}, #{title,jdbcType=VARCHAR}, 
      #{remark,jdbcType=VARCHAR}, #{creatdate,jdbcType=TIMESTAMP}, #{state,jdbcType=INTEGER}, 
      #{userId,jdbcType=INTEGER})
    <!-- 用于主键的回填 -->
    <selectKey keyProperty="id" resultType="int" order="AFTER">
    select last_insert_id()
    </selectKey>
  </insert>

希望能够帮到遇到相同问题的初学者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值