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 {int batchInsertOrUpdate(@Param("list") List list);
}
在Mapper XML文件中编写SQL语句,使用ON DUPLICATE KEY UPDATE
实现批量新增或修改,例如:
INSERT INTO user(username, password)VALUES(#{item.username}, #{item.password}) ON DUPLICATE KEY UPDATEusername = VALUES(username),password = VALUES(password)
上述代码中,使用
标签循环插入或更新每个User
对象,ON DUPLICATE KEY UPDATE
表示如果有唯一索引冲突,则执行更新操作。
在Service层中调用Mapper方法,例如:
@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic int batchInsertOrUpdate(List list) {return userMapper.batchInsertOrUpdate(list);}
}
这样,我们就可以通过一个方法实现基于唯一索引的批量新增或修改记录了。