MyBatisPlus-范围查询、模糊查询及排序查询

简介: MyBatisPlus-范围查询、模糊查询及排序查询

一、范围查询

需求:对年龄进行范围查询,使用lt()、le()、gt()、between()进行范围查询

@SpringBootTest 
class Mybatisplus02DqlApplicationTests { 
    @Autowired 
    private UserDao userDao; 
    @Test
    void testGetAll(){ 
        LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>(); 
        lqw.between(User::getAge, 10, 30); 
        //SELECT id,name,password,age,tel FROM user WHERE (age BETWEEN ? AND ?) 
        List<User> userList = userDao.selectList(lqw); 
        System.out.println(userList); 
    } 
}


gt():大于(>)

ge():大于等于(>=)

lt():小于(<)

lte():小于等于(<=)

between():between ? and ?

二、模糊查询

需求:查询表中name属性的值以3开头的用户信息,使用like进行模糊查询

@SpringBootTest 
class Mybatisplus02DqlApplicationTests { 
    @Autowired 
    private UserDao userDao; 
    @Test 
    void testGetAll(){ 
        LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>(); 
        lqw.likeLeft(User::getName, "J"); 
        //SELECT id,name,password,age,tel FROM user WHERE (name LIKE ?) 
        List<User> userList = userDao.selectList(lqw); 
        System.out.println(userList); 
    } 
}


like():前后加百分号,如 %J%

likeLeft():前面加百分号,如 %J

likeRight():后面加百分号,如 J%

三、排序查询

需求:查询所有数据,然后按照id降序

@SpringBootTest 
class Mybatisplus02DqlApplicationTests {
    @Autowired 
    private UserDao userDao; 
    @Test 
    void testGetAll(){ 
        LambdaQueryWrapper<User> lwq = new LambdaQueryWrapper<>(); 
        /**
            * condition :条件,返回boolean, 
                当condition为true,进行排序,如果为false,则不排序 
            * isAsc:是否为升序,true为升序,false为降序 
            * columns:需要操作的列 
        */ 
         lwq.orderBy(true,false, User::getId); 
        userDao.selectList(lw 
    } 
}

除了上面的演示方式,还有其他排序方法可以被调用:

e0f65949f9c44b82ab46e9a33dcb41a3.png


orderBy排序

● condition:条件,true则添加排序,false则不添加排序

● isAsc:是否为升序,true升序,false降序

● columns:排序字段,可以有多个

orderByAsc/Desc(单个column):按照指定字段进行升序/降序

orderByAsc/Desc(多个column):按照多个字段进行升序/降序

● orderByAsc/Desc

● condition:条件,true添加排序,false不添加排序


除了上面几种查询条件构建方法还有其他方法,比如isNull,isNotNull,notIn等等方法可供选择,具体可以参考官方文档的条件构造器俩学习使用,具体网址为:


条件构造器 | MyBatis-Plus (baomidou.com)

https://baomidou.com/pages/10c804/#abstractwrapper

目录
相关文章
|
16天前
|
XML Java 数据库连接
mybatis中在xml文件中通用查询结果列如何使用
mybatis中在xml文件中通用查询结果列如何使用
20 0
|
1月前
|
Java 关系型数据库 数据库连接
MyBatis Plus 解决大数据量查询慢问题
MyBatis Plus 解决大数据量查询慢问题
|
1月前
|
SQL Java 数据库连接
Mybatis查询的时候BigDecimal类型的值查询失效的解决办法
Mybatis查询的时候BigDecimal类型的值查询失效的解决办法
|
1月前
|
缓存 Java 数据库连接
MyBatis Plus的“幻查” 规范到底要怎样使用哪几个查询函数 为什么会出现幻查?还有幻删为什么会删不掉
MyBatis Plus的“幻查” 规范到底要怎样使用哪几个查询函数 为什么会出现幻查?还有幻删为什么会删不掉
|
1月前
|
SQL Java 关系型数据库
【MyBatis】3、一文介绍如何用 MyBatis 进行多表级联查询
【MyBatis】3、一文介绍如何用 MyBatis 进行多表级联查询
54 0
|
3月前
|
SQL Java 数据库连接
JAVAEE框架技术之9-myBatis高级查询技术文档
JAVAEE框架技术之9-myBatis高级查询技术文档
81 0
JAVAEE框架技术之9-myBatis高级查询技术文档
|
3月前
|
SQL Java 数据库连接
Mybatis之Mybatis的各种查询功能和特殊SQL的执行
【1月更文挑战第3天】 一、MyBatis的各种查询功能 1、查询一个实体类对象 2、查询一个List集合 3、查询单个数据 4、查询一条数据为map集合 5、查询多条数据为map集合 1、方法一 2、方法二 二、特殊SQL的执行 1、模糊查询 2、批量删除 3、动态设置表名 4、添加功能获取自增的主键
140 1
Mybatis之Mybatis的各种查询功能和特殊SQL的执行
|
3月前
|
Java 数据库连接 mybatis
一文彻底搞懂Mybatis系列(十三)之MyBatis一对多映射查询
一文彻底搞懂Mybatis系列(十三)之MyBatis一对多映射查询