首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MyBatis插入数据后返回主键id

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

1.7K10

深入浅出mybatis之返回主键ID

除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。...添加单一记录时返回主键ID 添加一条记录时返回主键值,在xml映射器和接口映射器中都可以实现。...需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键id。...System.out.println("id = " + test.getId()); // 执行添加操作之后通过Java对象获取主键属性值 添加批量记录时返回主键ID 如果希望执行批量添加并返回各记录主键字段值...获取主键ID实现原理 需要注意的是,不论在xml映射器还是在接口映射器中,添加记录的主键值并非添加操作的返回值。实际上,在MyBatis中执行添加操作时只会返回当前添加的记录数。

3.3K20

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

对特定数据库(如PostgreSQL),若自动生成的主键不是第一个字段则必须设置 keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中...取值范围oracle|mysql等,表示数据库厂家,元素内部可通过``来为特定数据库指定不同的sql语句 三、一般的INSERT操作——返回值为插入的记录数目...,但不同的是主键值已经赋值到领域模型实体的id中了。...其属性如下: keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中 resultType ,keyPropety...VALUES(#{item.name}, #{item.age}) 上述方式相当语句逐条INSERT语句执行,将出现如下问题: 1. mapper接口的add方法返回值将是最一条

5.2K80

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

比如添加一个用户,同时返回插入用户后得到的用户id: /** * 添加用户信息 * @param user * @throws Exception */...("com.danny.mybatis.insertUser", user); session.commit(); return user.getUserId();//返回插入数据库后得到的用户...id }   这里总结一下mybatis插入数据时返回主键的4种情况:mysql环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。   ...,查询并返回刚插入数据的主键(但是单独执行这条语句只会返回0)。...背 景数据库为oracle: 主键为自增时(主键为数值类型):   在oracle中实现主键自增,需要先创建序列,相当于创建一个全局变量,用来存储对应表的主键的当前最大值(主键为数值类型时)。

1.9K20

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 属性设置返回值类型。

59000

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

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

65330

基于Saas主键表生成主键id

1.主键生成策略方式 ? 主键生成策略 2.基于Saas主键表生成主键id流程 由于我们的系统时基于Saas的,因此生成主键时,需要以租户id(TenantId)为基础进行生成。...为了生成的id符合我们的租户的要求,通常都会现将租户表建好,然后基于租户表中的租户id进行主键id的生成。此时便产生基于租户id生成主键,那么怎样生成主键id呢?可以查看下图: ?...(* com.xtt..*.dao.mapper..*.insert*(..))") public void primaryKeyRule() {} 也就是说在进行主键的生成时,我们拦截好需要生成的主键...entity.getClass()); } } 此时通过反射拿到声明方法中的字段,下面针对单个新增进行说明: 通过字节码拿到声明的方法getId,如果此时存在id,则说明此时的操作是更新操作,因此直接返回...return current; } 从而实现主键自增的目的,从而实现基于租户id进行自增的策略。

1.7K20
领券