MyBatis-Plus关键功能使用

前言

用了好几年的MyBatis-Plus,有些偏僻的功能不经常用,去用的时候老是忘记,还需要重新查阅官网,借这篇文章的机会,记录一下,帮助他人也方便自己今后查阅。

部分功能

查询某些字段

有些时候查询的数据不需要返回全部字段,只返回业务中感兴趣的字段,所以我们可以用如下API

java 复制代码
User user = baseMapper.selectOne(new LambdaQueryWrapper<User>()
    .eq(User::getId, userId)
    .select(User::getName));//只有name字段有值
String userName = user.getName();

流式查询

MyBatis-Plus 从 3.5.4 版本开始支持流式查询,这是 MyBatis 的原生功能,通过 ResultHandler 接口实现结果集的流式查询。这种查询方式适用于数据跑批或处理大数据的业务场景。

常用方法

  • getResultObject: 获取数据库中的每一条记录。
  • getResultCount: 获取当前处理的结果集条数,每处理一条记录,该计数器会加1,计数从1开始。
  • stop: 停止继续处理结果集,相当于在循环中使用 break 语句。

使用示例

以下是使用流式查询的示例代码,展示了如何结合分页从数据库中拉取数据进行批量处理,以及如何获取表中的所有记录进行处理。

java 复制代码
// 结合分页,按批次从数据库拉取数据出来跑批,例如从数据库获取10万记录,做数据处理
Page<H2User> page = new Page<>(1, 100000);
baseMapper.selectList(page, Wrappers.emptyWrapper(), new ResultHandler<H2User>() {
    int count = 0;
    @Override
    public void handleResult(ResultContext<? extends H2User> resultContext) {
        H2User h2User = resultContext.getResultObject();
        System.out.println("当前处理第" + (++count) + "条记录: " + h2User);
        // 在这里进行你的业务处理,比如分发任务
    }
});

// 从数据库获取表所有记录,做数据处理
baseMapper.selectList(Wrappers.emptyWrapper(), new ResultHandler<H2User>() {
    int count = 0;
    @Override
    public void handleResult(ResultContext<? extends H2User> resultContext) {
        H2User h2User = resultContext.getResultObject();
        System.out.println("当前处理第" + (++count) + "条记录: " + h2User);
        // 在这里进行你的业务处理,比如分发任务
    }
});

在上述示例中,我们创建了一个 Page 对象来指定分页参数,然后调用 selectList 方法并传入 ResultHandler 来处理每一条记录。在 ResultHandler 的 handleResult 方法中,我们可以获取当前处理的记录,并进行相应的业务处理。通过计数器 count,我们可以知道当前处理的是第几条记录。

条件判断

Wrapper 方法通常接受一个 boolean 类型的参数,用于决定是否将该条件加入到最终的 SQL 中。

java 复制代码
queryWrapper.like(StringUtils.isNotBlank(name), Entity::getName, name)
            .eq(age != null && age >= 0, Entity::getAge, age);

如果某个方法没有显式提供 boolean 类型的参数,则默认为 true,即条件总是会被加入到 SQL 中。

相关推荐
Anastasiozzzz20 分钟前
MySQL深分页问题与优化思路
数据库·mysql
伯明翰java29 分钟前
数据库的操作
数据库
知识分享小能手4 小时前
PostgreSQL 入门学习教程,从入门到精通,PostgreSQL 16 语法知识点与案例详解(1)
数据库·学习·postgresql
康康的AI博客4 小时前
智能情感分析与品牌策略优化:如何通过AI洞察提升企业市场响应力
大数据·数据库·人工智能
Anastasiozzzz5 小时前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
ppp今天又没打瓦5 小时前
围达梦数据库批量插入更新性能实测:普通表、一级分区与二级分区的对决
数据库
@insist1235 小时前
软考-数据库系统工程师-计算机体系结构与流水线核心考点解析
数据库·软考·数据系统工程师
可观测性用观测云6 小时前
KES(KingbaseES)数据库监控最佳实践
数据库
新缸中之脑6 小时前
在Reddit上探索未满足的需求
数据库·oracle
安当加密6 小时前
用 SMS 凭据管理系统替代 HashiCorp Vault:中小企业的轻量级 Secrets 管理实践
服务器·数据库·安全·阿里云