MyBatisPlus唯一索引批量新增或修改的实现方法

2023-03-22 18:03:38 索引 批量 新增

mybatis-Plus提供了一个便捷的方式基于唯一索引批量新增或修改记录。具体步骤如下:

在实体类中标注唯一索引,使用@TableIndex注解,例如:

@TableName("user")
@TableIndex(name = "idx_username", unique = true, columnList = "username")
public class User {
    private Long id;
    private String username;
    private String passWord;
    // ...
}

上述代码中,@TableIndex注解表示在user表上创建一个名为idx_username的唯一索引,索引列为username。

在Mapper接口中定义方法,使用@Param注解传递参数,例如:

public interface UserMapper extends BaseMapper<User> {
    int batchInsertOrUpdate(@Param("list") List<User> list);
}

在Mapper XML文件中编写sql语句,使用ON DUPLICATE KEY UPDATE实现批量新增或修改,例如:

<insert id="batchInsertOrUpdate" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO user(username, password)
    VALUES
    <foreach collection="list" item="item" separator=",">
        (#{item.username}, #{item.password})
    </foreach>
    ON DUPLICATE KEY UPDATE
    username = VALUES(username),
    password = VALUES(password)
</insert>

上述代码中,使用<foreach>标签循环插入或更新每个User对象,ON DUPLICATE KEY UPDATE表示如果有唯一索引冲突,则执行更新操作。

在Service层中调用Mapper方法,例如:

@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private UserMapper userMapper;
 
    @Override
    public int batchInsertOrUpdate(List<User> list) {
        return userMapper.batchInsertOrUpdate(list);
    }
}

这样,我们就可以通过一个方法实现基于唯一索引的批量新增或修改记录了。

到此这篇关于MyBatisPlus唯一索引批量新增或修改的实现方法的文章就介绍到这了,更多相关MyBatisPlus唯一索引批量新增 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章