MyBatis获取插⼊记录的⾃增长字段值(ID)
第⼀步:
在Mybatis Mapper⽂件中添加属性“useGeneratedKeys”和“keyProperty”,其中keyProperty是Java对象的属性名!
<insert id="insert" parameterType="Spares"
useGeneratedKeys="true" keyProperty="id">
insert into spares(spares_id,spares_name,
spares_type_id,spares_spec)
insert语句字段顺序values(#{id},#{name},#{typeId},#{spec})
</insert>
第⼆步:
Mybatis执⾏完插⼊语句后,⾃动将⾃增长值赋值给对象Spares的属性id。因此,可通过Spares对应的getter⽅法获取!
/**
* 新增备件
* @author hellostory
* @param spares
* @return
*/
@RequestMapping(value = "/insert")
@ResponseBody
public JsonResponse insert(Spares spares) {
int count = sparesService.insert(spares);
System.out.println("共插⼊" + count + "条记录!"
+ "\n刚刚插⼊记录的主键⾃增长值为:" + Id());
ps:mybatis返回插⼊数据的⾃增长id
今天测试反馈⼀个bug,现象是新注册的⽤户可以看到所有⼈的报告,⽼⽤户没问题,查看⽇志发现原来查询的时候是新注册的⽤户的id为null,所以进⾏了全表有效数据查询。但是表的主键不允许为空,怎么会出现新的注册⽤户id为null呢?原因是在service层代码直接将参数对象返回了,⽽xml没有做任何配置。
具体的解决⽅案是在xml中的insert⽅法配置
useGeneratedKeys=”true” keyProperty=”registerId”
keyProperty值对应实体VO对象中的主键属性
具体如下:
<code class="hljs java">@Override
public Registers create(Registers r) {
registersMapper.insert(r);
return r;
}</code>
<code class="hljs xml"><insert id="insert" keyproperty="registerId" parametertype="aservice.pojo.base.Registers" usegeneratedkeys="true">执⾏正常的insert语句
</insert></code>
这样在controller层就可以得到新插⼊数据的⾃增长主键了。
关于在xml中添加两个属性的意思,⽹上解释如下:
useGeneratedKeys
(仅对insert有⽤)这会告诉MyBatis使⽤JDBC的getGeneratedKeys⽅法来取出由数据(⽐如:像MySQL和SQL Server这样的数据库管理系统的⾃动递增字段)内部⽣成的主键。默认值:false。
keyProperty
(仅对insert有⽤)标记⼀个属性,MyBatis会通过getGeneratedKeys或者通过insert语句的selectKey⼦元素设置它的值。默认:不设置。
总结
以上所述是⼩编给⼤家介绍的MyBatis获取插⼊记录的⾃增长字段值(ID),希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论