Mybatis插入空记录获得自增主键

来源:互联网 发布:ff14暗战捏脸数据 编辑:程序博客网 时间:2024/06/07 08:30

在以下情景中:

有一个商家表merhcant表和授权表oauth,在商家注册的时候(此时没有商家基本信息,只有注册账号密码信息),只会向oauth中插入数据,但是oauth表需要获得外键merhcant_id的值,也就是说必须先向merhcant表中插入一条空记录,并获得自增id,然后将该id作为oauth的外键插入到授权表oauth中

所以需要解决的问题时:在merhcant表中插入一条空记录,并返回自增主键

实例方法:mapper.xml中

<!-- 注册时插入无任何信息的记录,返回主键,使用insert语句 -->  <insert id="insertAndGetId" useGeneratedKeys="true" keyProperty="merchantId" parameterType="com.bididc.mall.pojo.Merchant">    insert into merchant() value();  </insert>

useGeneratedKeys=”true” 表示给主键设置自增长
keyProperty=”merchantId” 表示将自增长后的Id赋值给实体类Merchant中的merchantId字段
所以我们可以插入空记录,但是必须有实体类参数,这样返回的值就在该实体类参数的merchantId属性值中
这里写图片描述
mapper.java文件和插入的记录
这里写图片描述

参考:
https://www.cnblogs.com/xingyunblog/p/6243179.html
http://chenzhou123520.iteye.com/blog/1849881

原创粉丝点击