首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MyBatis插入数据返回主键id

最近开发全栈项目时,前端有个数据行可以被随便修改,所以必须给他一个标识记录该数据行,即向MySQL数据库中插入一条记录,需要获取此条记录的主键id值返回给前端。...content,name) values(#{articleTitle},#{articleCreateDate},#{articleContent},#{addName}) insert> 这种方式只是返回一个影响行数值...articleCreateDate},#{articleContent},#{addName}) 关键属性 useGeneratedKeys 仅适用于 insert 和 update,这会令 MyBatis...使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如MySQL的自动递增主键字段),默认值:false。...所以要打开设为 true keyProperty 仅适用于 insert 和 update,指定能够唯一识别对象的属性,MyBatis 会使用 getGeneratedKeys 的返回值或 insert

1.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

Mybatis映射文件深入 - 新增数据返回主键ID - 动态SQL - SQL片段

Mybatis映射文件深入 - 新增数据返回主键ID - 动态SQL - SQL片段 前言 在前面的篇章中,我们已经认识了如何使用 resultMap标签 映射查询的结果集字段、多条件查询、模糊查询。...下面我们继续来深入认识一下 MyBatis 的映射文件。 新增数据返回主键 ID 应用场景 向数据库保存一个user对象, 然后在控制台打印此新增user的主键值(id) # 点外卖 1....需要返回这条记录的主键, 然后给第三方配送平台, 送外卖 实现案例一:基于MyBatis 框架自带的主键返回功能 ① UserMapper接口 /* * # 复杂操作:插入一条数据返回对应的主键...int i = userMapper.addUser(user); System.out.println("插入数据的行数: " + i); //查询插入返回主键...2.4 知识小结 MyBatis映射文件配置 :查询 :插入 :修改 :删除 :插入返回主键 <where

1K30

mybatis插入数据返回自增主键ID详解

1.场景介绍: ​ 开发过程中我们经常性的会用到许多的中间表,用于数据之间的对应和关联.这个时候我们关联最多的就是ID,我们在一张表中插入数据级联增加到关联表中.我们熟知的mybatis在插入数据返回的是插入成功的条数...,那么这个时候我们想要得到相应的这条新增数据的ID,该怎么办呢?...2.插入数据返回自增主键ID方法(一) 在映射器中配置获取记录主键值 xml映射: 在xml中定义useGeneratedKeys为true,返回主键id的值,keyProperty和keyColumn...需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键id。...System.out.println("id = " + student.getId()); // 执行添加操作之后通过Java对象获取主键属性值 添加批量记录时返回主键ID 如果希望执行批量添加并返回各记录主键字段值

12.1K30

MyBatis框架点滴】——mybatis插入数据返回主键(mysql、oracle)

主键的值都是插入之前无法知道的,但很多情况下我们在插入数据需要使用刚刚插入数据的主键,比如向两张关联表A、B中插入数据(A的主键是B的外键),向A表中插入数据之后,向B表中插入数据时需要用到A的主键。...比如添加一个用户,同时返回插入用户得到的用户id: /** * 添加用户信息 * @param user * @throws Exception */...", user); session.commit(); return user.getUserId();//返回插入数据库得到的用户id }   这里总结一下mybatis...插入数据时返回主键的4种情况:mysql环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。   ...,查询并返回刚插入数据的主键(但是单独执行这条语句只会返回0)。

2K20

深入浅出mybatis返回主键ID

添加记录获取主键ID,这是一个很常见的需求,特别是在一次前端调用中需要插入多个表的场景。...除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。...需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键id。...获取主键ID实现原理 需要注意的是,不论在xml映射器还是在接口映射器中,添加记录的主键值并非添加操作的返回值。实际上,在MyBatis中执行添加操作时只会返回当前添加的记录数。...https://blog.csdn.net/jiangeeq/article/details/55047116 Mybatis批量插入返回插入成功主键id https://blog.csdn.net

3.4K20

MyBatis魔法堂:Insert操作详解(返回主键、批量插入)

下面记录MyBatis关于INSERT操作的笔记,以便日后查阅。...对特定数据库(如PostgreSQL),若自动生成的主键不是第一个字段则必须设置 keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中...MySQL和SQLServer执行auto-generated key field,因此当数据库设置好自增长主键,可通过JDBC的getGeneratedKeys方法获取。...parameterType="EStudent"> insert into TStudent(name, age) values(#{name}, #{age}) </insert 四、执行INSERT操作获取记录主键...八、参考                                       http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html

6.5K80

‍面试官问:MybatisMybatis-Plus执行插入语句可以返回主键ID吗? ‍我:看我回答...

一、Mybatis执行插入语句可以返回主键ID吗? 在想写什么内容的时候,正好看到一个基础面试题上有这个问题,就把它记录下来了。 ‍面试官:你说Mybatis执行插入语句可以返回主键ID吗??...keyProperty属性,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中,也就是你实体类中,对应数据库的主键id。...最后在实体类中,要有主键的get与set方法,满足,在impl层controller层,直接实体类.getId() 即可获取本次插入主键ID,返回前端即可。...二、Mybatis-Plus在执行插入语句返回自定义ID ‍面试官:那你会用Mybatis-Plus吗?Mybatis-Plus如何做这件事情啊,有简单的方式吗? ‍...一步一步道来: 可以直接使用Mybatis-Plus的sava方法,或者mapper层的insert方法,它都会将返回的结果自动填充进你映射的的实体类。从而可以直接获取到你的数据。

2.4K20

MyBatis框架:第四章:插入记录并返回主键

往数据库插入数据返回数据主键信息。有两种方法。 一种:使用insert标签中的useGeneratedKeys属性和keyProperty属性组合使用获取主键信息。...-- 插入用户useGeneratedKeys="true"表示返回生成的主键keyProperty 表示把返回的key注入到返回值的哪个属性中keyProperty="id" 表示把返回的id主键值注入到返回对象的...into t_user(last_name,sex) values(#{lastName},#{sex})12345678910标签的使用 selectKey 通过前置或后置操作,返回数据的主键值...插入记录并返回主键主要是在标签中添加一个的作用主要就是为了返回插入记录,自动生成的主键信息 order 表示执行的顺序。 AFTER 表示在插入之后执行。 BEFORE 在插入之前执行。...keyProperty 属性设置对象的哪个属性接收 resultType 属性设置返回值类型。

61400
领券