gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章MyBatis获取插入记录的自增长字段值(ID)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

第一步:

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

?
1
2
3
4
5
6
<insert id= "insert" parameterType= "Spares"
  useGeneratedKeys= "true" keyProperty= "id" >
  insert into spares(spares_id,spares_name,
   spares_type_id,spares_spec)
  values(#{id},#{name},#{typeId},#{spec})
  </insert>

第二步:

    Mybatis执行完插入语句后,自动将自增长值赋值给对象Spares的属性id。因此,可通过Spares对应的getter方法获取! 。

?
1
2
3
4
5
6
7
8
9
10
11
12
/**
* 新增备件
* @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方法配置 。

?
1
useGeneratedKeys=” true ” keyProperty=”registerId”

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

具体如下:

?
1
2
3
4
5
<code class = "hljs java" > @Override
   public Registers create(Registers r) {
     registersMapper.insert(r);
     return r;
   }</code>

registermapper.xml的insert方法如下:

?
1
<code class = "hljs xml" ><insert id= "insert" keyproperty= "registerId" parametertype= "com.ciji.zzaservice.pojo.base.Registers" usegeneratedkeys= "true" >

执行正常的insert语句 。

?
1
</insert></code>

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

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

useGeneratedKeys 。

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

keyProperty 。

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

总结 。

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

原文链接:https://my.oschina.net/u/3708595/blog/1577120 。

最后此篇关于MyBatis获取插入记录的自增长字段值(ID)的文章就讲到这里了,如果你想了解更多关于MyBatis获取插入记录的自增长字段值(ID)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com