服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - JAVA教程 - MyBatis获取插入记录的自增长字段值(ID)

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

2021-02-18 12:52robot_man JAVA教程

本文分步骤给大家介绍了MyBatis获取插入记录的自增长字段值的方法,在文中给大家提到了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

延伸 · 阅读

精彩推荐
  • JAVA教程详解JAVA 原型模式

    详解JAVA 原型模式

    这篇文章主要介绍了JAVA 原型模式的的相关资料,文中讲解非常细致,实例帮助大家更好的理解和学习,感兴趣的朋友可以了解下 ...

    菜鸟教程5112020-06-29
  • JAVA教程类似Object监视器方法的Condition接口(详解)

    类似Object监视器方法的Condition接口(详解)

    下面小编就为大家带来一篇类似Object监视器方法的Condition接口(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看...

    Java教程网4812020-11-02
  • JAVA教程浅谈Java 三种方式实现接口校验

    浅谈Java 三种方式实现接口校验

    这篇文章主要介绍了浅谈Java 三种方式实现接口校验,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    BarryW11352021-01-21
  • JAVA教程基于Protobuf动态解析在Java中的应用 包含例子程序

    基于Protobuf动态解析在Java中的应用 包含例子程序

    下面小编就为大家带来一篇基于Protobuf动态解析在Java中的应用 包含例子程序。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过...

    Java教程网3472020-12-05
  • JAVA教程Java泛型详解

    Java泛型详解

    本文给大家汇总介绍了下java中的泛型的相关资料,包括引入泛型机制的原因,泛型类,泛型方法,泛型的实现以及泛型的注意事项,非常的详细,有需要的...

    hebedich3142020-04-11
  • JAVA教程Java RandomAccessFile的用法详解

    Java RandomAccessFile的用法详解

    下面小编就为大家带来一篇Java RandomAccessFile的用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...

    jingxian2932020-05-12
  • JAVA教程java中抽象类、抽象方法、接口与实现接口实例详解

    java中抽象类、抽象方法、接口与实现接口实例详解

    这篇文章主要给大家介绍了关于java中抽象类、抽象方法、接口与实现接口的相关资料,文中通过示例代码将四者介绍的非常详细,并且简单介绍了抽象类和...

    YJLAugus3852021-01-30
  • JAVA教程BootStrap Jstree 树形菜单的增删改查的实现源码

    BootStrap Jstree 树形菜单的增删改查的实现源码

    这篇文章主要介绍了BootStrap Jstree 树形菜单的增删改查的实现源码,非常不错,具有参考借鉴价值,需要的朋友可以参考下 ...

    _PPB1702020-08-14