Mybatis主子表关联插入时,获取插入到主表的id

项目中,我们主表和关联表进行连表插入的时候,我们往主表中插入数据的ID可能是自动生成的,那么这个时候我们往关联表里插入数据时没有主表的主键id!我们可以通过MySQL的函数LAST_INSERT_ID,进行获取!他对比useGeneratedKeys="true"的好处就是,一旦数据库主键生成的随机方法比较复杂,他就没法获取!推荐做法就是:
order="AFTER",让这个语句放在其他语句之后来执行!

    <insert id="add" parameterType="com.itheima.pojo.CheckGroup">
        
        /*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>

你可能感兴趣的:(笔记,mysql,mybatis,java)