mybatis plus常用操作

1.条件更新指定字段

java 复制代码
UpdateWrapper<ExamParticipation> updateWrapper = new UpdateWrapper<>();
updateWrapper.lambda()
    .eq(ExamParticipation::getId, id)
    .set(ExamParticipation::getField1, value1)
    .set(ExamParticipation::getField2, value2)
    .set(ExamParticipation::getField3, value3);

int rows = examParticipationMapper.update(null, updateWrapper);

2.条件批量更新

MyBatis-Plus 也支持批量更新操作。你可以使用 UpdateWrapper 类的 in 方法来指定批量更新的条件。

以下是一个示例代码,演示如何使用 MyBatis-Plus 进行批量更新:

java 复制代码
List<Long> ids = Arrays.asList(1L, 2L, 3L);
List<String> values = Arrays.asList("value1", "value2", "value3");

UpdateWrapper<ExamParticipation> updateWrapper = new UpdateWrapper<>();
updateWrapper.lambda()
    .in(ExamParticipation::getId, ids)
    .set(ExamParticipation::getField1, values);

int rows = examParticipationMapper.update(null, updateWrapper);

3.批量新增

MyBatis-Plus 也支持批量新增操作。你可以使用 MyBatis-Plus 提供的 saveBatch 或 saveBatchSomeColumn 方法来实现批量新增。

以下是一个示例代码,演示如何使用 MyBatis-Plus 进行批量新增:

java 复制代码
List<ExamParticipation> examParticipations = new ArrayList<>();
examParticipations.add(new ExamParticipation(field1, field2, field3));
examParticipations.add(new ExamParticipation(field1, field2, field3));
examParticipations.add(new ExamParticipation(field1, field2, field3));

boolean success = examParticipationService.saveBatch(examParticipations);

上述代码中,ExamParticipation 是实体类,examParticipationService 是对应的 Service 类。

首先,创建一个 List 对象,包含要新增的实体对象,每个实体对象表示一条记录。

接下来,调用 saveBatch 方法来执行批量新增操作。参数为实体对象的列表。

saveBatch 方法将会返回一个布尔值,表示批量新增操作是否成功。

4.批量新增部分字段

另外,如果你只想新增部分字段,可以使用 saveBatchSomeColumn 方法,

java 复制代码
List<ExamParticipation> examParticipations = new ArrayList<>();
examParticipations.add(new ExamParticipation(field1, field2, field3));
examParticipations.add(new ExamParticipation(field1, field2, field3));
examParticipations.add(new ExamParticipation(field1, field2, field3));

boolean success = examParticipationService.saveBatchSomeColumn(examParticipations);

5.联表查询

MyBatis-Plus 支持联表查询操作。你可以使用 MyBatis-Plus 提供的方法来实现联表查询,其中包括使用 @TableField 注解进行关联映射,以及使用 @TableName 注解指定表名。

以下是一个示例代码,演示如何使用 MyBatis-Plus 进行联表查询:

java 复制代码
public List<Order> getOrdersWithUser() {
    return orderMapper.selectList(new QueryWrapper<Order>()
        .select("order.*", "user.user_name")
        .leftJoin("user", "user.id = order.user_id")
        .eq("order.status", "paid")
    );
}
相关推荐
木风小助理2 分钟前
JavaAtomicInteger底层实现深度解析
java
BD_Marathon8 分钟前
搭建MyBatis框架之创建MyBatis的映射文件(五)
java·数据库·mybatis
一只叫煤球的猫9 分钟前
为什么Java里面,Service 层不直接返回 Result 对象?
java·spring boot·面试
洛阳泰山9 分钟前
智能体项目MaxKB4J - 本地部署与开发完整指南
java·agent·工作流·rag·智能体·maxkb
Solar202515 分钟前
机械制造业TOB企业获客软件选型指南:从挑战到解决方案的深度解析
java·大数据·服务器·架构·云计算
橘子真甜~17 分钟前
Reids命令原理与应用5 - Redis 主从同步与高可用集群
运维·网络·数据库·redis·缓存·redis集群·redis高可用
2501_9481949818 分钟前
RN for OpenHarmony AnimeHub项目实战:放送时间表页面开发
数据库·redis·缓存
松涛和鸣21 分钟前
DAY52 7-Segment Display/GPIO/Buttons/Interrupts/Timers/PWM
c语言·数据库·单片机·sqlite·html
想摆烂的不会研究的研究生26 分钟前
每日八股——Redis(3)
数据库·redis·后端·缓存
寂寞恋上夜30 分钟前
数据迁移方案怎么写:迁移策略/回滚方案/验证方法(附完整模板)
网络·数据库·oracle·markdown转xmind·deepseek思维导图