项目中,我们主表和关联表进行连表插入的时候,我们往主表中插入数据的ID可能是自动生成的,那么这个时候我们往关联表里插入数据时没有主表的主键id!我们可以通过MySQL的函数LAST_INSERT_ID
,进行获取!他对比useGeneratedKeys="true"
的好处就是,一旦数据库主键生成的随机方法比较复杂,他就没法获取!推荐做法就是:
order="AFTER"
,让这个语句放在其他语句之后来执行!
<insert id="add" parameterType="com.itheima.pojo.CheckGroup">
<!--通过mybatis框架提供的selectKey标签获得自增产生的ID值-->
/*order="AFTER",声明当前select语句在insert后面执行*/
<selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="id">
select LAST_INSERT_ID()
</selectKey>
insert into t_checkgroup(code,name,sex,helpCode,remark,attention)
values
(#{code},#{name},#{sex},#{helpCode},#{remark},#{attention})
</insert>