前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mybatis中通用Mapper的InsertList()

Mybatis中通用Mapper的InsertList()

原创
作者头像
用户4396583
发布2024-08-06 08:51:39
1590
发布2024-08-06 08:51:39

针对通用Mapper中批量新增时是否需要自增ID或者自定义ID时需要使用不同包下的insertList()

通常批量插入的ID非自增的ID(及自定义生成ID策略),所以tk.mybatis.mapper.additional.insert.InsertListMapper包下的

insertList()经常用在项目组中,配合@Intercepts 自定义 Mybatis 拦截 update 操作(添加和修改)

1. tk.mybatis.mapper.common.special.InsertListMapper包下的insertList()方法:

pom导入:

代码语言:xml
复制
<dependency>
	<groupId>tk.mybatis</groupId>
	<artifactId>mapper-base</artifactId>
</dependency>
<dependency>
	<groupId>tk.mybatis</groupId>
	<artifactId>mapper-core</artifactId>
</dependency>

使用该方法的实体类主键必须是自增的(需要在实体类中指出)。

如果实体的主键名为’id’,同时主键自增。在不修改代码的情况下,使用insertList()方法实现的批量插入数据后通用mapper能自动回写主键值到实体对象中。

如以下实体类和对应mapper:

代码语言:java
复制
@Data
@Table(name = "user")
public class User {
    @Id
    @KeySql(useGeneratedKeys = true)
    private Integer id;
    private String username;
    private String desc;
}

public interface UserMapper extends InsertListMapper<User> {

}

如果实体类主键名不是id,同时实体类主键是自增的,想要实现实体类主键回写,需要重写insertList()方法,其实就是修改了注解上的值,把@Options注解上的keyProperty值改为自己实体类的主键名

如以下实体类和对应的mapper:

代码语言:java
复制
@Data
@Table(name = "user")
public class User {
   @Id
   @KeySql(useGeneratedKeys = true)
   private Integer uid;
   private String username;
   private String desc;
}

public interface UserMapper extends Mapper<User>, InsertListMapper<User> {

    @Options(keyProperty = "uid",useGeneratedKeys = true)
    @InsertProvider(type = SpecialProvider.class, method = "dynamicSQL")
    int insertList(List<User> recordList);
}

2. tk.mybatis.mapper.additional.insert.InsertListMapper包下的insertList()方法:

pom导入:

代码语言:xml
复制
<!-- https://mvnrepository.com/artifact/tk.mybatis/mapper-extra -->
<dependency>
	<groupId>tk.mybatis</groupId>
	<artifactId>mapper-extra</artifactId>
	<version>1.1.5</version>
</dependency>

该方法不支持主键策略,需要在实体类中指定主键。该方法执行后不会回写实体类的主键值。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. tk.mybatis.mapper.common.special.InsertListMapper包下的insertList()方法:
  • 2. tk.mybatis.mapper.additional.insert.InsertListMapper包下的insertList()方法:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档