MyBatis获取插入记录的自增长字段值(ID)

网友投稿 371 2023-03-14


MyBatis获取插入记录的自增长字段值(ID)

第一步:

hZaVKSPSF

在Mybatis Mapper文件中添加属性“useGeneratedKeys”和“keyProperty”,其中keyProperty是java对象的属性名!

useGeneratedKeys="true" keyProperty="id">

insert into spares(hZaVKSPSFspares_id,spares_name,

spares_type_id,spares_spec)

values(#{id},#{name},#{typeId},#{spec})

useGeneratedKeys="true" keyProperty="id">

insert into spares(hZaVKSPSFspares_id,spares_name,

spares_type_id,spares_spec)

values(#{id},#{name},#{typeId},#{spec})

第二步:

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刚刚插入记录的主键自增长值为:" + spares.getId());

ps:mybatis返回插入数据的自增长id

今天测试反馈一个bug,现象是新注册的用户可以看到所有人的报告,老用户没问题,查看日志发现原来查询的时候是新注册的用户的id为null,所以进行了全表有效数据查询。 但是表的主键不允许为空,怎么会出现新的注册用户id为null呢?原因是在service层代码直接将参数对象返回了,而xml没有做任何配置。

具体的解决方案是在xml中的insert方法配置

useGeneratedKeys=”true” keyProperty=”registerId”

keyProperty值对应实体VO对象中的主键属性

具体如下:

@Override

public Registers create(Registers r) {

registersMapper.insert(r);

return r;

}

registermapper.xml的insert方法如下:

执行正常的insert语句

这样在controller层就可以得到新插入数据的自增长主键了。

关于在xml中添加两个属性的意思,网上解释如下:

useGeneratedKeys

(仅对insert有用)这会告诉MyBatis使用JDBC的getGeneratedKeys方法来取出由数据(比如:像mysql和SQL Server这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。

keyProperty

(仅对insert有用)标记一个属性,MyBatis会通过getGeneratedKeys或者通过insert语句的selectKey子元素设置它的值。默认:不设置。

总结

以上所述是给大家介绍的MyBatis获取插入记录的自增长字段值(ID),希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:路由器什么是管理员密码(路由器什么是管理员密码啊)
下一篇:开放平台接口测试管理办法(接口开放平台开源)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~