MyBatis:条件构造器QueryWrapper方法详解
QueryWrapper
说明:
继承自 AbstractWrapper ,自身的内部属性 entity 也用于生成 where 条件
及 LambdaQueryWrapper, 可以通过 new QueryWrapper().lambda() 方法获取.
测试用表:

1. eq、ne
说明:
eq:等于,ne:不等于
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> wrapper = new QueryWrapper<>();
//eq() 等于
wrapper.eq("last_name", "皮皮虾");
Employee one = employeeService.getOne(wrapper);
System.out.println(one);
}

@Test
public void contextLoads(){
QueryWrapper<Employee> wrapper = new QueryWrapper<>();
//ne() 不等于
wrapper.ne("gender", 0);
List<Employee> list = employeeService.list(wrapper);
System.out.println(list);
}

2. gt、ge、lt、le
说明:
gt:大于,ge:大于等于,lt:小于,le:小于等于
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> gtWrapper = new QueryWrapper<>();
//gt() 大于
gtWrapper.gt("age", 27);
List<Employee> gtList = employeeService.list(gtWrapper);
System.out.println(gtList); //********************** QueryWrapper<Employee> geWrapper = new QueryWrapper<>();
//ge() 大于等于
geWrapper.ge("age", 26);
List<Employee> geList = employeeService.list(geWrapper);
System.out.println(geList);
}

@Test
public void contextLoads(){
QueryWrapper<Employee> ltWrapper = new QueryWrapper<>();
//lt() 小于
ltWrapper.lt("age", 12);
List<Employee> ltList = employeeService.list(ltWrapper);
System.out.println(ltList); //********************** QueryWrapper<Employee> geWrapper = new QueryWrapper<>();
//le() 小于等于
leWrapper.le("age", 12);
List<Employee> leList = employeeService.list(leWrapper);
System.out.println(leList);
}

3. between、notBetween
说明:
between:在值1和值2之间,notBetween:不在值1和值2之间
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> betweenWrapper = new QueryWrapper<>();
//between() 区间的值
betweenWrapper.between("age", 10, 20);
List<Employee> betweenList = employeeService.list(betweenWrapper);
System.out.println(betweenList ); //********************** QueryWrapper<Employee> notBetweenWrapper = new QueryWrapper<>();
//notBetween() 不在区间的值
notBetweenWrapper.notBetween("age", 10, 21);
List<Employee> notBetweenList = employeeService.list(notBetweenWrapper );
System.out.println(notBetweenList );
}

4. like、notLike、likeLeft、likeRight
说明:
like:’%值%’,notLike:’%值%’,likeLeft:’%值’,likeRight:'值%'
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> likeWrapper = new QueryWrapper<>();
//like() 模糊查询匹配值
likeWrapper.like("last_name", "s");
List<Employee> likeList = employeeService.list(likeWrapper);
System.out.println(likeList ); //********************** QueryWrapper<Employee> notLikeWrapper = new QueryWrapper<>();
//notLike() 模糊查询不匹配值
notLikeWrapper.notLike("last_name", "s");
List<Employee> notLikeList = employeeService.list(notLikeWrapper);
System.out.println(notLikeList);
}

@Test
public void contextLoads(){
QueryWrapper<Employee> likeLeftWrapper = new QueryWrapper<>();
//likeLeft() 模糊查询匹配最后一位值
likeLeftWrapper.likeLeft("last_name", "s");
List<Employee> likeLeftList = employeeService.list(likeLeftWrapper);
System.out.println(likeLeftList ); //********************** QueryWrapper<Employee> likeRightWrapper = new QueryWrapper<>();
//likeRight() 模糊查询匹配第一位值
likeRightWrapper.likeRight("last_name", "s");
List<Employee> likeRightList = employeeService.list(likeRightWrapper );
System.out.println(likeRightList );
}

5. isNull、isNotNull
说明:
isNull:字段 IS NULL,isNotNull:字段 IS NOT NULL
测试:

@Test
public void contextLoads(){
QueryWrapper<Employee> isNullWrapper = new QueryWrapper<>();
//isNull() 为空
isNullWrapper.isNull("email");
List<Employee> isNullList = employeeService.list(isNullWrapper);
System.out.println(isNullList ); //********************** QueryWrapper<Employee> isNotNullWrapper = new QueryWrapper<>();
//isNotNull() 不为空
isNotNullWrapper.isNotNull("last_name", "s");
List<Employee> isNotNullList = employeeService.list(isNotNullWrapper );
System.out.println(isNotNullList );
}

6. in、notIn
说明:
in:字段 IN (v0, v1, …),notIn:字段 NOT IN (value.get(0), value.get(1), …)
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> inWrapper = new QueryWrapper<>();
//in() 符合多个条件的值
inWrapper.in("age", 8, 16, 26);
List<Employee> inList = employeeService.list(inWrapper);
System.out.println(inList ); //********************** QueryWrapper<Employee> notInWrapper= new QueryWrapper<>();
//notIn() 不符合多个条件的值
notInWrapper.notIn("age", 8, 16, 26);
List<Employee> notInList = employeeService.list(notInWrapper);
System.out.println(notInList );
}

7. or、and
说明:
or:或者 ,and:和
注意事项:
主动调用or表示紧接着下一个方法不是用and连接!(不调用or则默认为使用and连接)
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> orWrapper = new QueryWrapper<>();
//or() 查询age大于20 或者 gender等于1 的数据
orWrapper.gt("age", 20).or().eq("gender", 1);
List<Employee> orList = employeeService.list(orWrapper);
System.out.println(orList );
}

@Test
public void contextLoads(){
QueryWrapper<Employee> andWrapper = new QueryWrapper<>();
//and() 查询last_name等于皮皮虾b 和 gender等于1 的数据 (不使用and() 默认就是and())
andWrapper.eq("last_name", "皮皮虾b").eq("gender", 1);
List<Employee> andList = employeeService.list(andWrapper );
System.out.println(andList);
}

8. orderByAsc、orderByDesc
说明:
orderByAsc:升序:ORDER BY 字段, … ASC,orderByDesc:降序:ORDER BY 字段, … DESC
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> Wrapper = new QueryWrapper<>();
//orderByAsc() 升序排序
Wrapper.orderByAsc("id");
List<Employee> list = employeeService.list(Wrapper);
for(Employee e : list) {
System.out.println(e);
}
}

@Test
public void contextLoads(){
QueryWrapper<Employee> Wrapper = new QueryWrapper<>();
//orderByDesc() 降序排序
Wrapper.orderByDesc("id");
List<Employee> list = employeeService.list(Wrapper);
for(Employee e : list) {
System.out.println(e);
}
}

9. inSql、notInSql (不常用)
说明:
inSql:字段 IN ( sql语句 ),notInSql:字段 NOT IN ( sql语句 )
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> inSqlWrapper = new QueryWrapper<>();
//inSql() 符合sql语句的值
inSqlWrapper .inSql("select id from employee where id < 10");
List<Employee> inSqlList = employeeService.list(inSqlWrapper );
System.out.println(inSqlList ); //********************** QueryWrapper<Employee> notInSqlWrapper= new QueryWrapper<>();
//notInSql() 不符合sql语句的值
notInSqlWrapper.notInSql("select id from employee where id < 10");
List<Employee> notInSqlList = employeeService.list(notInSqlWrapper);
System.out.println(notInSqlList );
}

10. exists、notExists (不常用)
说明:
exists:拼接 EXISTS ( sql语句 ),notExists:拼接 NOT EXISTS ( sql语句 )
测试:
@Test
public void contextLoads(){
QueryWrapper<Employee> existsWrapper = new QueryWrapper<>();
//exists() 查询符合sql语句的值
existsWrapper.exists("select last_name,gender from employee where id = 1");
List<Employee> existsList = employeeService.list(existsWrapper);
System.out.println(existsList ); //********************** QueryWrapper<Employee> notExistsWrapper = new QueryWrapper<>();
//notExists() 查询不符合sql语句的值
notExistsWrapper.notExists("select last_name,gender from employee where id = 1");
List<Employee> notExistsList = employeeService.list(notExistsWrapper);
System.out.println(notExistsList ); }

文章转载至:https://blog.csdn.net/llllllkkkkkooooo/article/details/108216957
MyBatis:条件构造器QueryWrapper方法详解的更多相关文章
- MybatisPlus学习(四)条件构造器Wrapper方法详解
文章目录 1.条件构造器 2.QueryWrapper 2.1.eq.ne 2.2.gt.ge.lt.le 2.3.between.notBetween 2.4.like.notLike.likeLe ...
- MP实战系列(十二)之封装方法详解(续二)
继续MP实战系列(十一)之封装方法详解(续一)这篇文章之后. 此次要讲的是关于查询. 查询是用的比较多的,查询很重要,好的查询,加上索引如鱼得水,不好的查询加再多索引也是无济于事. 1.selectB ...
- MP实战系列(十一)之封装方法详解(续一)
之前写的封装方法详解,比较简要. 今天我主要讲增加和删除及其修改.查的话得单独再详讲. 增删改查,无论是Java或者C#等等,凡是对数据库操作的都离不开这四个. 一.增加方法讲解 MyBatis Pl ...
- Quartz学习——SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解(转)
通过前面的学习,你可能大致了解了Quartz,本篇博文为你打开学习SSMM+Quartz的旅程!欢迎上车,开始美好的旅程! 本篇是在SSM框架基础上进行的. 参考文章: 1.Quartz学习——Qua ...
- 《深入理解mybatis原理6》 MyBatis的一级缓存实现详解 及使用注意事项
<深入理解mybatis原理> MyBatis的一级缓存实现详解 及使用注意事项 0.写在前面 MyBatis是一个简单,小巧但功能非常强大的ORM开源框架,它的功能强大也体现在它的缓 ...
- [转载]Mybatis Generator最完整配置详解
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...
- 008-Scala主构造器、私有构造器、构造器重载实战详解
008-Scala主构造器.私有构造器.构造器重载实战详解 Scala主构造器实战 无参数的主构造器 分析 1.name 需要赋初值,一般通过占位符来代表空值 2.private 声明私有的age 生 ...
- C++调用JAVA方法详解
C++调用JAVA方法详解 博客分类: 本文主要参考http://tech.ccidnet.com/art/1081/20050413/237901_1.html 上的文章. C++ ...
- $.each()方法详解
$.each()方法详解 each()函数具有十分强大的遍历功能,可以遍历一维数组.多维数组.Dom.Json等. 在JavaScript中使用$.each可以大大减轻我们的工作量. 1.处理一维数组 ...
随机推荐
- git cherry-pick(不同分支的提交合并)
git cherry-pick可以选择某一个分支中的一个或几个commit(s)来进行操作.例如,假设我们有个稳定版本的分支,叫v2.0,另外还有个开发版本的分支v3.0,我们不能直接把两个分支合并, ...
- linux python3安装whl包时报错解决:is not a supported wheel on this platform
原因1 你下载安装的包不是当前平台所支持的 原因2 你下载的包,不符合你所在的平台的安装whl的名称规范,所以出错.比如当前我要安装的包是:pymssql-2.1.5-cp36-cp36m-manyl ...
- tkinter是内置的模块,不同的版本的导入形式不同,现总结如下
#coding=utf-8 import os, sys try: from tkinter import * except ImportError: #Python 2.x PythonVersio ...
- html原生js实现99乘法表
原生的js实现99乘法表实现选择下拉框颜色,改变背景颜色为选中的颜色 <!DOCTYPE html> <html> <head> <meta charset= ...
- Spring Cloud Alibaba系列之分布式服务组件Dubbo
本博客的例子代码可以在github找到下载链接:代码下载 SpringBoot.SpringCloud Alibaba系列博客专栏:链接 1.分布式理论 1.1.分布式基本定义 <分布式系统原理 ...
- 微信小程序从开发到上线流程
一.微信小程序从开发到上线流程 注册小程序 1.登录微信公众平台 https://mp.weixin.qq.com 2.在微信公众平台>立即注册>小程序中注册微信小程序 3.在邮箱中激活并 ...
- 目标检测coco数据集点滴介绍
目标检测coco数据集点滴介绍 1. COCO数据集介绍 MS COCO 是google 开源的大型数据集, 分为目标检测.分割.关键点检测三大任务, 数据集主要由图片和json 标签文件组成. c ...
- ISP算法高水平分析(下)
ISP算法高水平分析(下) 十.LSC(Lens Shade Correction)------镜头阴影矫正 Lens Shading指画面四角由于入射光线不足形成的暗角,同时,由于不同频率的光折射 ...
- 对端边缘云网络计算模式:透明计算、移动边缘计算、雾计算和Cloudlet
对端边缘云网络计算模式:透明计算.移动边缘计算.雾计算和Cloudlet 概要 将数据发送到云端进行分析是过去几十年的一个突出趋势,推动了云计算成为主流计算范式.然而,物联网时代设备数量和数据流量的急 ...
- 二、特殊DNS解析
一.DNS轮询 1.为站点 www.tedu.cn 提供DNS轮询解析,三台Web服务器节点的IP地址分别为: 192.168.4.10.192.168.4.20.192.168,4.30 步骤: 虚 ...