Mybatis的selectKey作用

本文详细解析MyBatis框架中@SelectKey注解的使用方法,包括其属性如keyProperty、resultType、order及statementType的含义,通过示例展示如何在插入操作后获取自增ID。

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

@SelectKey

属性描述
keyPropertyselectKey 语句结果应该被设置的目标属性。
resultType结果的类型。MyBatis 通常可以算出来,但是写上也没有问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。
order这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后是 selectKey 元素-这和如 Oracle 数据库相似,可以在插入语句中嵌入序列调用。
statementType和前面的相 同,MyBatis 支持 STATEMENT ,PREPARED 和CALLABLE 语句的映射类型,分别代表 PreparedStatement 和CallableStatement 类型。

我们可在使用id自增时通过@SelectKey返回最新插入的id;

例如:

    @Insert("insert into order_info(user_id, goods_id, goods_name, goods_count, goods_price, order_channel, status, create_date)values("
            + "#{userId}, #{goodsId}, #{goodsName}, #{goodsCount}, #{goodsPrice}, #{orderChannel},#{status},#{createDate} )")
    @SelectKey(keyColumn="id", keyProperty="id", resultType=long.class, before=false, statement="select last_insert_id()")
    long insert(OrderInfo orderInfo);

这样我们在服务层就能获取插入后的订单ID号了

        long orderId = orderDao.insert(orderInfo);
### 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、付费专栏及课程。

余额充值