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

 更新时间:2017年11月22日 11:13:32   作者:robot_man  
本文分步骤给大家介绍了MyBatis获取插入记录的自增长字段值的方法,在文中给大家提到了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)
 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刚刚插入记录的主键自增长值为:" + spares.getId());

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>

registermapper.xml的insert方法如下:

<code class="hljs xml"><insert id="insert" keyproperty="registerId" parametertype="com.ciji.zzaservice.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),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • JVM(Java Virtual Machine,Java虚拟机)的作用详解

    JVM(Java Virtual Machine,Java虚拟机)的作用详解

    JVM是Java语言实现“一次编写,到处运行”特性的基石,也是Java平台的核心组成部分,其主要作用包括平台无关性、内存管理、运行Java程序、安全性以及性能优化,通过这些功能,JVM确保了Java程序的可移植性、高效性和安全性
    2025-03-03
  • 介绍java中Pair(配对)

    介绍java中Pair(配对)

    这篇文章主要介绍了介绍java中Pair(配对),示例描述使用Pair类实现简单Integer到String的映射,示例中getKey方法返回key对象,getValue方法返回对应值对象,需要的朋友可以参考下
    2023-03-03
  • Java实现八种排序算法详细代码举例

    Java实现八种排序算法详细代码举例

    排序问题一直是程序员工作与面试的重点,今天特意整理研究下与大家共勉!这篇文章主要介绍了Java实现八种排序算法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-10-10
  • 使用java操作elasticsearch的具体方法

    使用java操作elasticsearch的具体方法

    本篇文章主要介绍了使用java操作elasticsearch的具体方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Java8实战之Stream的延迟计算

    Java8实战之Stream的延迟计算

    JDK中Stream的中间函数如 filter(Predicate super T>)是惰性求值的,filter并非对流中所有元素调用传递给它的Predicate,下面这篇文章主要给大家介绍了关于Java8实战之Stream延迟计算的相关资料,需要的朋友可以参考下
    2021-09-09
  • SpringBoot+fileUpload获取文件上传进度

    SpringBoot+fileUpload获取文件上传进度

    这篇文章主要为大家详细介绍了SpringBoot+fileUpload获取文件上传进度,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Java设计模式之单件模式深入讲解

    Java设计模式之单件模式深入讲解

    有人说单件模式是最简单的模式,因为它只有一个类,但其实它还有一些值得注意的地方,就如:出现并发性时,单件可能已经不是单件了
    2021-11-11
  • java用静态工厂代替构造函数使用方法和优缺点

    java用静态工厂代替构造函数使用方法和优缺点

    这篇文章主要介绍了java用静态工厂代替构造函数使用方法和优缺点,需要的朋友可以参考下
    2014-02-02
  • IDEA maven引入SSL证书校验问题及处理

    IDEA maven引入SSL证书校验问题及处理

    这篇文章主要讨论了在Maven项目中遇到依赖导入问题,特别是关于PKIX路径构建失败的错误,文章提供了三种解决方法:手动下载依赖、忽略SSL证书校验以及生成并导入SSL证书,每种方法都有详细的步骤和示例代码,帮助开发者解决这个问题
    2025-02-02
  • Maven安装本地的jar包和创建带模板的自定义项目的操作过程

    Maven安装本地的jar包和创建带模板的自定义项目的操作过程

    这篇文章主要介绍了Maven安装本地的jar包和创建带模板的自定义项目,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-03-03

最新评论