Mybatis:selectKey标签

本文讲述了在使用SSM框架前,作者在处理多表级联添加时遇到的问题,即如何在主表插入后获取PK值用于次表插入。通过学习Mybatis的selectKey标签,作者了解到该标签能有效解决这一问题。selectKey可以在before或after插入操作中生成主键,方便后续操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在学习SSM框架之前的我在做项目的时候,总是在惆怅在多表级联添加的时候,怎么在主表插入完成后获取到其PK的值然后作为第二张表的PK来插入。
当时,我只能写成两个方法,做两次的数据库操作,显然这非常的蠢且繁琐,但是当时啥也不会,只能勤劳地打了几十行的代码,就为了实现这么一个操作。

学习mybatis,select Key之后……

对应的几个必要的参数↓

属性名使用方式
keyProperty对应应该被设置的目标属性
resultType该属性的类型
order下面详细演示

当order="before"时,那么会先生成主键,如下2、3图,可以直接拿到,然后再执行插入语句。

<!-- 插入数据 -->
<insert id="insertStudent" parameterType="net.dfrz.entity.Student">
	<selectKey keyProperty="stuID" resultType="String" order="BEFORE">
		select replace(uuid(),"-","")
	</selectKey>
	insert into t_student(stuID,name,birthday,sex) values(#{stuID},#{name},#{birthday},#{sex})
</insert>

在这里插入图片描述
在这里插入图片描述

所以,当为after的时候,一般情况下就时再insert之后,再取得ID,一般出现在PK时AutoIncrease的情况下,你必须插入后才能拿到对应的PK值。

### MyBatis 使用 `selectKey` 实现批量插入的功能 在 MyBatis 中,`selectKey` 是用来设置主键回填的一种机制。当需要实现批量插入时,可以通过组合使用 `<foreach>` 和 `selectKey` 来满足需求。以下是具体的实现方式和代码示例。 #### 批量插入的核心思路 为了支持批量插入操作,通常会采用以下方法: 1. **动态生成主键**:对于每一条记录,通过 `selectKey` 动态生成唯一的主键值。 2. **循环处理数据集合**:利用 MyBatis 的 `<foreach>` 标签遍历传入的参数列表,并逐一插入到数据库中[^1]。 #### XML 映射文件配置 下面是一个完整的 Mapper 文件配置实例,展示如何结合 `selectKey` 和 `<foreach>` 完成批量插入功能。 ```xml <insert id="batchInsertUsers" parameterType="java.util.List"> <!-- 开启事务 --> BEGIN; <foreach collection="list" item="item" index="index" separator=";"> <!-- 单条插入语句 --> INSERT INTO user_entity (id, username, password, comment) VALUES ( #{item.id}, #{item.username}, #{item.password}, #{item.comment} ); <!-- 自动为主键赋值 --> <selectKey resultType="java.lang.String" keyProperty="item.id" order="BEFORE"> SELECT UUID() AS id FROM DUAL </selectKey> </foreach> COMMIT; </insert> ``` 在这个例子中: - `collection="list"` 表明输入的是一个 Java List 对象。 - `separator=";"` 确保每次插入之间用分号隔开。 - `order="BEFORE"` 指定 `selectKey` 应该发生在实际插入之前,从而先获取主键再执行插入动作[^2]。 > 注意:以上 SQL 片段适用于 MySQL 数据库环境下的 UUID 函数调用。如果是 Oracle 数据库,则可能需要用序列或其他手段代替 `UUID()` 函数。 #### Java 接口定义 相应的 BaseMapper 接口中应声明如下方法签名: ```java public interface UserMapper extends BaseMapper<UserEntity> { void batchInsertUsers(@Param("list") List<UserEntity> userList); } ``` 这样就可以直接调用这个接口的方法来进行批量插入了。 #### 测试案例 准备一组测试数据并通过服务层调用上述方法验证效果: ```java List<UserEntity> users = new ArrayList<>(); for(int i=0;i<5;i++) { UserEntity entity = new UserEntity(); // 只需填充非主键字段即可 entity.setUsername("TestUser"+i); entity.setPassword("Passw0rd!"); entity.setComment("This is a test record."); users.add(entity); } // 调用 mapper 进行批插 userMapper.batchInsertUsers(users); ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值