当前位置: 首页 > news >正文

Mybatis在新增某个数据后,如何获取新增数据的id

在某些业务中,我们在新增一条数据之后,需要拿到这条数据的id来对这条数据进行后续的一个操作,如何拿取id呢?
使用的是<insert> 中的useGeneratedKeys 和 keyProperty 两个属性

1.在Mybatis Mapper文件中添加属性 “useGeneratedKeys”和“keyProperty”,其中 keyProperty 是 Java 对象的属性名,而不是表格的字段名。

<insert id="insert" parameterType="Spares"  useGeneratedKeys="true" keyProperty="id">  insert into system(name) values(#{name})  
</insert> 

2.Mybatis 执行完插入语句后,自动将自增长值赋值给对象 systemBean(指的是你自己创建的对象) 的属性id。因此,可通过 systemBean 对应的 getter 方法获取!

int count = systemService.insert(systemBean);  
int id = systemBean.getId(); //获取到的即为新插入记录的ID 

【注意事项】

  1. Mybatis Mapper 文件中,“useGeneratedKeys” 和 “keyProperty” 必须添加,而且 keyProperty 一定得和 java 对象的属性名称一直,而不是表格的字段名。

  2. java Dao中的 Insert 方法,传递的参数必须为 java 对象,也就是 Bean,而不能是某个参数。

http://www.lryc.cn/news/261957.html

相关文章:

  • 12.4~12.14概率论复习与相应理解(学习、复习、备考概率论,这一篇就够了)
  • 关于多重背包的笔记
  • 如何使用 Java 的反射
  • PLC-Recorder V3 修改服务器和客户端通讯端口的方法
  • libevent服务GET/POST的简单使用
  • MySQL 系列:注意 ORDER 和 LIMIT 联合使用的陷阱
  • 通过实例理解OAuth2授权
  • MATLAB2022安装下载教程
  • 从零开始搭建Go语言开发环境
  • vite+vue3+ts+tsx+ant-design-vue项目框架搭建
  • 【5G PHY】5G小区类型、小区组和小区节点的概念介绍
  • 创建个人网站(一)从零开始配置环境,搭建项目
  • fripside - promise lrc
  • 网络连接和协议
  • MySQL数据库,表的增量备份与恢复
  • 13.Spring 整合 Kafka + 发送系统通知 + 显示系统通知
  • windows 服务器 怎么部署python 程序
  • Chapter 7 - 2. Congestion Management in Ethernet Storage Networks以太网存储网络的拥塞管理
  • 深入理解前端项目中的 package.json
  • 4-Docker命令之docker build
  • Hdfs java API
  • 大数据Doris(三十七):索引和Rollup基本概念和案例演示
  • 2019年第八届数学建模国际赛小美赛B题数据中心冷出风口的设计解题全过程文档及程序
  • mmpose 使用笔记
  • <url-pattern>/</url-pattern>与<url-pattern>/*</url-pattern>的区别
  • Spring IoCDI
  • vue使用el-tag完成添加标签操作
  • ACM-MM2023 DITN详解:一个部署友好的超分Transformer
  • STM32超声波——HC_SR04
  • [Excel] vlookup函数