mybatis的selectKey作用

本文介绍了MyBatis中SelectKey的功能与用法,详细解释了如何针对不同数据库配置SelectKey来实现主键生成,包括MySQL和Oracle的具体配置示例。

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

SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。

 使用mybatis的selectKey就可以得到sequence的值,同时也会将值返回。不过对于不同的数据库有不同的操作方式。


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


SelectKey需要注意order属性,像MySQL一类支持自动增长类型的数据库中,order需要设置为after才会取到正确的值。

Oracle这样取序列的情况,需要设置为before,否则会报错。

下面是一个xml和注解的例子,SelectKey很简单,两个例子就够了:

[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <insert id="insert" parameterType="map">  
  2.     insert into table1 (name) values (#{name})  
  3.     <selectKey resultType="java.lang.Integer" keyProperty="id">  
  4.       CALL IDENTITY()  
  5.     </selectKey>  
  6.   </insert>  

上面xml的传入参数是map,selectKey会将结果放到入参数map中。用POJO的情况一样,但是有一点需要注意的是,keyProperty对应的字段在POJO中必须有相应的setter方法,setter的参数类型还要一致,否则会报错。


  对于oracle: 
      <insert id="insertUser" parameterClass="XXX.User"> 
          <selectKey resultClass="long" keyProperty="id"order="BEFORE"
              select SEQ_USER_ID.nextval as id from dual 
          </selectKey> 
           insert into user  (id,name,password) 
          values (#{id},#{name},#{password}) 
      </insert> 
       这句话会在插入user之前执行(order="BEFORE"),该句话执行完之后,会生成一个ID,传进来的参数User对象里的id字段就会被赋值成sequence的值。 

     对于mysql 
     <insert id="insertUser" parameterClass="XXX.User"> 
          insert into user (name,password) 
         values (#{id},#{name},#{password}) 
          <selectKey resultClass="long" keyProperty="id" order="after">  
             SELECT LAST_INSERT_ID() AS ID  
        </selectKey>  
      </insert> 
       将selectKey放在insert之后,通过LAST_INSERT_ID() 获得刚插入的自动增长的id的值。插入之后获得ID赋值到传进来的对象中(对象中必须有相应的属性)。

### 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、付费专栏及课程。

余额充值