一文掌握MyBatis Plus的条件构造器方法
作者:世界尽头与你 发布时间:2023-06-18 13:00:26
标签:MyBatis,Plus,条件构造器
1.组装查询条件
组装查询其实很简单,可以支持条件的链式编程:
查询用户名包含a,年龄在 10 - 20 之间并且邮箱不为空的用户:
@Test
void contextLoads() {
// 查询用户名包含a,年龄在 10 - 20 之间并且邮箱不为空的用户
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.like("name","a")
.between("age",10,20)
.isNotNull("email");
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (name LIKE ? AND age BETWEEN ? AND ? AND email IS NOT NULL)
==> Parameters: %a%(String), 10(Integer), 20(Integer)
<== Columns: id, name, age, email, is_delete
<== Row: 2, dada, 11, 111@qq.com, 0
<== Row: 4, dahe, 12, 34567@qq.com, 0
<== Total: 2
2.组装排序条件
查询用户信息,按照年龄的降序排序,若年龄相同,则按照id升序排序:
@Test
void contextLoads() {
// 查询用户信息,按照年龄的降序排序,若年龄相同,则按照id升序排序
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.orderByDesc("age").orderByAsc("id");
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 ORDER BY age DESC,id ASC
==> Parameters:
<== Columns: id, name, age, email, is_delete
<== Row: 3, dahe, 33, 34567@qq.com, 0
<== Row: 4, dahe, 12, 34567@qq.com, 0
<== Row: 2, dada, 11, 111@qq.com, 0
<== Total: 3
3.使用Lambda表达式解决条件优先级
将用户名中包含有a并且(年龄大于20或邮箱为null)的用户信息查询出来:
Lambda中的条件优先执行!
@Test
void contextLoads() {
// 将用户名中包含有a并且(年龄大于20或邮箱为null)的用户信息查询出来
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.like("name", "a")
.and(i -> i.gt("age", 20).or().isNull("email"));
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (name LIKE ? AND (age > ? OR email IS NULL))
==> Parameters: %a%(String), 20(Integer)
<== Columns: id, name, age, email, is_delete
<== Row: 3, dahe, 33, 34567@qq.com, 0
<== Total: 1
4.组装select语句
有时我们不想查询数据库某张表的所有字段,可以使用maps集合选择只查询某些字段的值:
@Test
void contextLoads() {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("name","email");
List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);
maps.forEach(System.out::println);
}
==> Preparing: SELECT name,email FROM user WHERE is_delete=0
==> Parameters:
<== Columns: name, email
<== Row: dada, 111@qq.com
<== Row: dahe, 34567@qq.com
<== Row: dahe, 34567@qq.com
<== Total: 3
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@237add]
{name=dada, email=111@qq.com}
{name=dahe, email=34567@qq.com}
{name=dahe, email=34567@qq.com}
5.组装子查询
@Test
void contextLoads() {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.inSql("id","select id from user where id > 1");
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (id IN (select id from user where id > 1))
==> Parameters:
<== Columns: id, name, age, email, is_delete
<== Row: 2, dada, 11, 111@qq.com, 0
<== Row: 3, dahe, 33, 34567@qq.com, 0
<== Row: 4, dahe, 12, 34567@qq.com, 0
<== Total: 3
6.使用UpdateWrapper实现修改功能
将名字中包含a的记录修改:
@Test
void contextLoads() {
// 将名字中包含a的记录修改
UpdateWrapper<User> wrapper = new UpdateWrapper<>();
wrapper.like("name","a");
wrapper.set("name","hello").set("age",18);
userMapper.update(null, wrapper);
}
JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@36c07c75] will not be managed by Spring
==> Preparing: UPDATE user SET name=?,age=? WHERE is_delete=0 AND (name LIKE ?)
==> Parameters: hello(String), 18(Integer), %a%(String)
<== Updates: 3
7.模拟开发中组装条件的情况
真实的开发中往往有这样的情况:我们不知道前端传来的条件是什么,此时无法正常的拼接sql,那么就需要在后端进行相应的判断:
@Test
void contextLoads() {
String name = null;
Integer ageBegin = 18;
Integer ageEnd = 28;
QueryWrapper<User> wrapper = new QueryWrapper<>();
if (StringUtils.isNotBlank(name)) {
wrapper.like("name", name);
}
if (ageBegin != null) {
wrapper.ge("age", ageBegin);
}
if (ageEnd != null) {
wrapper.le("age", ageEnd);
}
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (age >= ? AND age <= ?)
==> Parameters: 18(Integer), 28(Integer)
<== Columns: id, name, age, email, is_delete
<== Row: 3, hello, 18, 34567@qq.com, 0
<== Row: 4, hello, 18, 34567@qq.com, 0
<== Total: 2
但是,这样的判断我们认为过于的简陋和复杂,事实上,MyBatis Plus的条件构造器中为我们封装了解决此类问题的一些重载方法:
@Test
void contextLoads() {
String name = null;
Integer ageBegin = 18;
Integer ageEnd = 28;
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.like(StringUtils.isNotBlank(name), "name", name);
wrapper.ge(ageBegin != null, "age", ageBegin);
wrapper.le(ageEnd != null, "age", ageEnd);
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (age >= ? AND age <= ?)
==> Parameters: 18(Integer), 28(Integer)
<== Columns: id, name, age, email, is_delete
<== Row: 3, hello, 18, 34567@qq.com, 0
<== Row: 4, hello, 18, 34567@qq.com, 0
<== Total: 2
8.LambdaQueryWrapper和LambdaUpdateWrapper
使用LambdaQueryWrapper
和LambdaUpdateWrapper
可以防止我们的字段名修改导致的程序错误或字段名写错
例如:
@Test
void contextLoads() {
String name = null;
Integer ageBegin = 18;
Integer ageEnd = 28;
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.like(StringUtils.isNotBlank(name), User::getName, name);
wrapper.ge(ageBegin != null, User::getAge, ageBegin);
wrapper.le(ageEnd != null, User::getAge, ageEnd);
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
==> Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 AND (age >= ? AND age <= ?)
==> Parameters: 18(Integer), 28(Integer)
<== Columns: id, name, age, email, is_delete
<== Row: 3, hello, 18, 34567@qq.com, 0
<== Row: 4, hello, 18, 34567@qq.com, 0
<== Total: 2
LambdaUpdateWrapper
的使用方法类似
来源:https://blog.csdn.net/Gherbirthday0916/article/details/128902090


猜你喜欢
- 1.使用ASCII码判断您可以使用ASCII码来进行判断字符串中的内容是否为纯数字。步骤如下:先判断字符串是否为空的情况,保证代码运行的稳定
- 本文实例讲述了Java中的 * 、过滤器、 * 用法。分享给大家供大家参考,具体如下:一、 * :是在面向切面编程的就是在你的servic
- 内存泄露,是Android开发者最头疼的事。可能一处小小的内存泄露,都可能是毁千里之堤的蚁穴。 怎么才能检测内存泄露呢? AndroidSt
- 首先来看效果: 一、实现原理在实现过程中,主要考虑整个界面由若干个字母组成的子母线条组成,这样的话把固定数量的字母封装成一个字母线条,而每个
- 众所周知,在墙内开发很头疼的一件事就是Maven仓库的连接速度太慢。虽然对于很多互联网企业和大中型软件公司,建个镜像是分分钟的事。但对于个人
- 1. ThreadLocal详解JDK1.2版本起,Java就提供了java.lang.ThreadLocal,ThreadLocal为每个
- 本文实例为大家分享了Java代码对HDFS进行增删改查操作的具体代码,供大家参考,具体内容如下import java.io.File;imp
- C#Windows server2016服务器搭建NFS共享文件夹与C#上传图片到共享文件夹nfs共享文件夹实现步骤基于:Windows s
- 一、作用:随机流(RandomAccessFile)不属于IO流,支持对文件的读取和写入随机访问。二、随机访问文件原理: 首先把随机访问的文
- 本文实例讲述了Android开发之ListView列表刷新和加载更多实现方法。分享给大家供大家参考。具体如下:上下拉实现刷新和加载更多的Li
- 1、注解(Annotation)1.1 什么是注解(Annotation)注解不是程序本身,可以在程序编译、类加载和运行时被读取,并执行相应
- 首先我们要明白一下几点,1.代码写出来除了让他跑起来还有个非常非常重要的作用是维护,因为没有一成不变的代码,需求变化代码就不可避免的要变化。
- TextView文本大小自动适配与TextView边距的去除标题太难取了,其实本文主要就是讲如何控制文本大小,让其自动适配宽度,其次我们还需
- 最近项目上用就hibernate+spring data jpa,一开始感觉还不错,但是随着对业务的复杂,要求处理一些复杂的sql,就顺便研
- “Hello World!”的程序写过不少,不过都是在黑色背景的控制台上显示白色的文字。这次决定写点特别的,让“Hello World!”变
- 背景最近在研究搭建spring源码调试环境时,接触到到gradle项目构建工具。由于之前习惯于maven项目的构建,故通过此文记录相关gra
- 概述对于多线程程序来说,生产者和消费者模型是非常经典的模型。更加准确的说,应该叫“生产者-消费者-仓库模型”。离开了仓库,生产者、消费者就缺
- mybatis insert foreach循环插入@Insert("<script>" +
- LottieLottie 是 Airbnb 开源的一个动画项目,它支持 iOS, mac OS Android RN,由于某些复杂动画的实现
- 分页是Java Web项目常用的功能,昨天在Spring MVC中实现了简单的分页操作和搜索分页,在此记录一下。使用的框架为(MyBatis