在以下情景中:
有一个商家表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