文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

一文掌握MyBatis Plus的条件构造器方法

2023-02-09 09:00

关注

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

使用LambdaQueryWrapperLambdaUpdateWrapper可以防止我们的字段名修改导致的程序错误或字段名写错

例如:

@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的使用方法类似

到此这篇关于MyBatis Plus的条件构造器的文章就介绍到这了,更多相关MyBatis Plus的条件构造器内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯