【学习笔记】Mybatis-Plus(三):MP中Wrapper的使用

Wrapper简介

注意:

查询用QueryWrapper和LambdaQueryWrapper来封装

updateWrapper和LambdaUPdateWrapper不但能封装查询还能更改要更新的对象。

QueryWrapper的使用

QueryWrapper中的很多条件限定都是见名知其意的。下表列出来几个常用的:

1.多条件进行查询

java 复制代码
@Test
public void test01() {
    //查询用户,姓李的 & 年龄从20岁到30岁内 & 地址是北京朝阳的
    QueryWrapper<User> queryWrapper = new QueryWrapper();
    queryWrapper.likeRight("name", "李")
            .between("age", 20, 30)
            .eq("address", "北京朝阳");
    List<User> users = this.userMapper.selectList(queryWrapper);
    users.forEach(System.out::println);
}
//sql语句
==>  Preparing: SELECT id,name,age,email,address AS addr,
createtime,updatetime,is_deleted FROM lm_user 
WHERE is_deleted=0 AND (name LIKE ? AND age BETWEEN ? AND ? AND address = ?)
==> Parameters: 李%(String), 20(Integer), 30(Integer), 北京朝阳(String)

2.有排序查询

java 复制代码
@Test
public void test02() {
    //按年龄降序查询用户,如果年龄相同则按id升序排列
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.orderByDesc("age")
            .orderByAsc("id");
    List<User> users = this.userMapper.selectList(queryWrapper);
    users.forEach(System.out::println);
}
//sql语句
SELECT id,name,age,email,address AS addr,createtime,updatetime,is_deleted 
FROM lm_user WHERE is_deleted=0 ORDER BY age DESC,id ASC

3.条件优先级查询

java 复制代码
@Test
public void test03() {
    //(年龄大于20并且用户名中包含有张)或邮箱为null的用户信息
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.gt("age", 20)
            .like("name", "张")
            .or()
            .isNull("email");
    this.userMapper.selectList(queryWrapper);
    //用户名中包含有张并且(年龄大于20或邮箱为null)的用户信息
    QueryWrapper<User> query = new QueryWrapper<>();
    query.like("name", "张")
            .and(wrapper -> wrapper.gt("age", 20).or().isNull("email"));
    this.userMapper.selectList(query);
}
//sql语句
==>  Preparing: SELECT id,name,age,email,address AS addr,
createtime,updatetime,is_deleted FROM lm_user 
WHERE is_deleted=0 AND (age > ? AND name LIKE ? OR email IS NULL)
==> Parameters: 20(Integer), %张%(String)
==>  Preparing: SELECT id,name,age,email,address AS addr,
createtime,updatetime,is_deleted FROM lm_user 
WHERE is_deleted=0 AND (name LIKE ? AND (age > ? OR email IS NULL))
==> Parameters: %张%(String), 20(Integer)

LambdaQueryWrapper的使用

用LamdaQueryWrapper的好处是数据库的字段名不用手写了,可以避免写错的风险。用法和QueryWrapper差不多。

java 复制代码
@Test
public void test04() {
    //(年龄大于20并且用户名中包含有张)或邮箱为null的用户信息
    LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper();
    queryWrapper.gt(User::getAge, 20)
            .like(User::getName, "张")
            .or()
            .isNull(User::getEmail);
    List<User> userList = this.userMapper.selectList(queryWrapper);
    userList.forEach(System.out::println);

    //采用链式更方便。查询结果和上面一样的
    List<User> users = new LambdaQueryChainWrapper<>(this.userMapper)
            .gt(User::getAge, 20)
            .like(User::getName, "张")
            .or()
            .isNull(User::getEmail)
            .list();
    users.forEach(System.out::println);
}
//sql语句
==>  Preparing: SELECT id,name,age,email,address AS addr,
createtime,updatetime,is_deleted FROM lm_user 
WHERE is_deleted=0 AND (age > ? AND name LIKE ? OR email IS NULL)
==> Parameters: 20(Integer), %张%(String)

UpdateWrapper的使用

java 复制代码
@Test
public void test05() {
    //通过UpdateWrapper进行更新
    UpdateWrapper<User> updateWrapper = new UpdateWrapper();
    updateWrapper.gt("age", 20)
            .like("name", "张")
            .or()
            .isNull("email")
            .set("age", 23);
    this.userMapper.update(null, updateWrapper);

    //链式方式进行更新
    UpdateChainWrapper<User> updateChainWrapper = new UpdateChainWrapper<>(this.userMapper);
    updateChainWrapper.gt("age", 20)
            .like("name", "张")
            .or()
            .isNull("email")
            .set("age", 23).update();
}
//sql语句
==>  Preparing: UPDATE lm_user SET age=? WHERE is_deleted=0 
AND (age > ? AND name LIKE ? OR email IS NULL)
==> Parameters: 23(Integer), 20(Integer), %张%(String)

LambdaUpdateWrapper

java 复制代码
@Test
public void test06() {
    boolean result = new LambdaUpdateChainWrapper<User>(this.userMapper)
            .set(User::getAge, 23)
            .set(User::getEmail, "[email protected]")
            .gt(User::getAge, 20)
            .like(User::getName, "张")
            .or()
            .isNull(User::getEmail)
            .update();
    System.out.println("更新结果:" + result);
}
//sql语句
==>  Preparing: UPDATE lm_user SET age=?,email=? WHERE is_deleted=0 AND (age > ? AND name LIKE ? OR email IS NULL)
==> Parameters: 23(Integer), [email protected](String), 20(Integer), %张%(String)

有条件时才加入条件

在实际开发过程中在拼接条件时,经常是判断这个值不为null,空字符串时才加入条件。这个在MP中再每个条件设置的第一个参数condition就是用来判断是否加入条件的条件。

java 复制代码
@Test
public void test07() {
    User request = new User();
    request.setAge(null);
    request.setName("老马");
    request.setEmail("[email protected]");
    List<User> users = new LambdaQueryChainWrapper<>(this.userMapper)
            .select(User::getId, User::getName, User::getAge, User::getEmail)
            .gt(request.getAge()!=null, User::getAge, 20)
            .like(StringUtils.isNotBlank(request.getName()), User::getName, request.getName())
            .eq(StringUtils.isNotBlank(request.getEmail()), User::getEmail, request.getEmail())
            .list();
    users.forEach(System.out::println);
}
//sql语句
==>  Preparing: SELECT id,name,age,email FROM lm_user 
WHERE is_deleted=0 AND (name LIKE ? AND email = ?)
==> Parameters: %老马%(String), [email protected](String)
相关推荐
ghost1431 分钟前
C#学习第18天:特性(Attributes)
开发语言·学习·c#
小羊不会飞2 小时前
Towards Transferable Targeted 3D Adversarial Attack in the Physical World--阅读笔记
笔记
栀栀栀栀栀栀3 小时前
笔记 2025/4/23
笔记
樱花穿过千岛湖4 小时前
第六章:Multi-Backend Configuration
人工智能·python·gpt·学习·ai
大刘讲IT5 小时前
数据治理体系的“三驾马车”:质量、安全与价值挖掘
大数据·运维·经验分享·学习·安全·制造·零售
名字越长技术越强5 小时前
Node.js学习
学习·node.js
Rey_family6 小时前
CSS学习笔记
css·笔记·学习
SuperW6 小时前
Linux学习——UDP
linux·学习·udp
宇柔6 小时前
JavaEE学习笔记(第二课)
笔记·学习·java-ee
zhaoyqcsdn7 小时前
抽象工厂模式及其在自动驾驶中的应用举例(c++代码实现)
c++·经验分享·笔记·设计模式