news 2026/6/15 5:17:24

mybatis insert后返回id

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
mybatis insert后返回id

在 MyBatis 中插入数据后返回自增 ID 有以下几种常用方法:

1.使用useGeneratedKeyskeyProperty(推荐)

XML 映射文件方式

<insert id="insertUser" parameterType="User" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name, age) VALUES(#{name}, #{age}) </insert>

注解方式

@Insert("INSERT INTO user(name, age) VALUES(#{name}, #{age})") @Options(useGeneratedKeys = true, keyProperty = "id") int insertUser(User user);

2.使用<selectKey>元素(支持更多数据库)

MySQL

<insert id="insertUser" parameterType="User"> <selectKey keyProperty="id" resultType="int" order="AFTER"> SELECT LAST_INSERT_ID() </selectKey> INSERT INTO user(name, age) VALUES(#{name}, #{age}) </insert>

Oracle

<insert id="insertUser" parameterType="User"> <selectKey keyProperty="id" resultType="int" order="BEFORE"> SELECT SEQ_USER.NEXTVAL FROM DUAL </selectKey> INSERT INTO user(id, name, age) VALUES(#{id}, #{name}, #{age}) </insert>

PostgreSQL

<insert id="insertUser" parameterType="User"> <selectKey keyProperty="id" resultType="int" order="AFTER"> SELECT currval('user_id_seq') </selectKey> INSERT INTO user(name, age) VALUES(#{name}, #{age}) </insert>

3.Java 代码中使用

// 实体类 public class User { private Integer id; // 主键属性 private String name; private Integer age; // getter/setter... } // 使用示例 User user = new User(); user.setName("张三"); user.setAge(25); // 执行插入 int result = userMapper.insertUser(user); // 插入后,id 会自动设置到 user 对象中 System.out.println("生成的ID:" + user.getId()); // 直接获取

4.批量插入返回 ID

MySQL

<insert id="batchInsert" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name, age) VALUES <foreach collection="list" item="item" separator=","> (#{item.name}, #{item.age}) </foreach> </insert>
List<User> userList = new ArrayList<>(); // 添加多个 user userMapper.batchInsert(userList); // 每个 user 对象的 id 都会被自动设置

5.注意事项

  1. 数据库支持:需要数据库支持自增主键

  2. keyProperty 配置:必须与实体类的主键属性名一致

  3. 事务管理:在事务中,ID 会在事务提交后才真正确定

  4. 连接池:使用连接池时,确保useGeneratedKeys能正常工作

6.返回多个自增 ID(批量)

<insert id="batchInsertUsers" parameterType="java.util.List" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name, age) VALUES <foreach collection="list" item="user" separator=","> (#{user.name}, #{user.age}) </foreach> </insert>

7.返回非自增的 ID(如 UUID)

// 在插入前生成 ID String uuid = UUID.randomUUID().toString(); user.setId(uuid); userMapper.insert(user); // 或者通过 selectKey 生成

推荐使用方式

  • MySQL/PostgreSQL:使用useGeneratedKeys

  • Oracle:使用<selectKey>BEFORE模式

  • 批量插入:确保连接池配置支持返回多个 ID

这样插入后,ID 会自动填充到传入的实体对象中,无需额外查询。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 16:57:12

Type Hints:花1小時寫,省18小時除錯的投資回報率分析

Type Hints&#xff1a;花1小時寫&#xff0c;省18小時除錯的投資回報率分析引言&#xff1a;一場效率革命在現代軟體開發中&#xff0c;我們經常面臨一個抉擇&#xff1a;應該花時間寫更嚴謹的程式碼&#xff0c;還是快速實現功能&#xff1f;Type Hints&#xff08;類型提示&…

作者头像 李华
网站建设 2026/6/13 11:33:14

基于大数据的国产跑鞋推荐与可视化分析系统(毕设源码+文档)

课题说明随着全民健身热潮兴起与国产运动品牌崛起&#xff0c;国产跑鞋市场规模持续扩大&#xff0c;但消费者普遍面临品类选择繁杂、适配需求匹配不精准、产品核心信息获取碎片化等问题&#xff0c;同时品牌方存在用户需求洞察不充分、产品优化缺乏数据支撑等痛点&#xff0c;…

作者头像 李华
网站建设 2026/5/26 21:49:16

美团战略携手赚转鱼科技 定义黄金回收“即时服务”新时代

——“上门即检、现场即付”创新模式借力超级平台&#xff0c;冲击传统行业格局深圳&#xff0c;2025年12月24日——近日&#xff0c;本地生活服务领域的领导者美团相关负责人与创新型科技企业深圳市赚转鱼科技有限公司业务部总监曾科文、人力总监覃丽莉、运营部负责人袁妙萍、…

作者头像 李华
网站建设 2026/6/10 23:46:03

香港科技大学突破性研究:让AI像指挥乐团一样看懂长视频

这项由香港科技大学刘润涛、刘子艺、唐嘉琦、马悦、皮仁杰、张季鹏和陈启峰等研究团队共同完成的研究于2025年12月发表在arXiv预印本平台上&#xff0c;论文编号为arXiv:2512.20618v1。有兴趣深入了解的读者可以通过该编号查询完整论文。当我们坐在电视机前观看一部两小时的电影…

作者头像 李华