Mybatis-plus动态条件查询QueryWrapper的使用

Mybatis-plus动态条件查询QueryWrapper的使用

一:queryWrapper介绍

queryWrapper是mybatis plus中实现查询的对象封装操作类,可以封装sql对象,包括where条件,order by排序,select哪些字段等等,他的层级关系如下图:

复制代码
Wrapper:条件构造抽象类,最顶端父类;
AbstractWrapper:用于查询条件封装,生成sql的where条件;
AbstractLambdaWrapper:Lambda语法使用Wrapper统一处理解析lambda获取column。
LambdaQueryWrapper:用于lambda语法使用的查询Wrapper;
LambdaUpdateWrapper:Lambda更新封装Wrapper;
QueryWrapper:Entity对象封装操作类,不是用lambda;
UpdateWrapper:Update条件封装,用于Entity对象更新操作。

二:queryWrapper示例

2.1-案例一:根据name模糊查看未删除的用户列表信息

过滤条件:

复制代码
name 用户名称 ,模糊查看
del_flag = 0
按照create_time创建时间降序
sql实现:

select * from t_user
where del_flag = 0
<if test ="name!=null and ''!=name">
    and name like concat('%',#{name},'%')
</if>
order by create_time desc

queryWrapper实现:

复制代码
/**
 * 案例一:根据name模糊查看未删除的用户列表信息
 * @param name
 * @return
 */
@RequestMapping("/list")
public Map<String,Object> getList(@RequestParam String name){
    Map<String,Object> result = new HashMap<>();

	//构建一个查询的wrapper
    QueryWrapper<User> wrapper = new QueryWrapper<User>();
    //name不为空时,组装模糊查询条件
    wrapper.like(StringUtils.isNotBlank(name),"name",name);
    //未删除
    wrapper.eq("del_flag",0);
    //创建时间降序
    wrapper.orderByDesc("create_time");

    List<User> list = userMapper.selectList(wrapper);
    result.put("data",list);
    return result;
}

2.2-案例二:查看姓李的并且邮箱不为空的用户列表

sql实现:

bash 复制代码
select * from t_user
where del_flag = 0
and name like concat('李','%')
and email is not null
order by create_time desc

queryWrapper实现:

复制代码
/**
 * 案例二:查看姓张的并且邮箱不为空的用户列表
 * @return
 */
@RequestMapping("/list2")
public Map<String,Object> getList2(){
    Map<String,Object> result = new HashMap<>();

    //构建一个查询的wrapper
    QueryWrapper<User> wrapper = new QueryWrapper<User>();
    //姓张的
    wrapper.likeRight("name","张");
    //邮箱不为空
    wrapper.isNotNull("email");
    //未删除
    wrapper.eq("del_flag",0);
    //创建时间降序
    wrapper.orderByDesc("create_time");

    List<User> list = userMapper.selectList(wrapper);
    result.put("data",list);
    return result;
}

2.3-案例三:年龄范围查询(20-30之间的)

sql实现:

bash 复制代码
select * from t_user
where del_flag=0
and age between 20 and 30
order by create_time desc

queryWrapper实现:

复制代码
/**
 * 案例三:年龄范围查询(20-30之间的)
 * @return
 */
@RequestMapping("/list3")
public Map<String,Object> getList3(){
    Map<String,Object> result = new HashMap<>();

    //构建一个查询的wrapper
    QueryWrapper<User> wrapper = new QueryWrapper<User>();
    //年龄20-30之间的
    wrapper.between("age",20,30);
    //未删除
    wrapper.eq("del_flag",0);
    //创建时间降序
    wrapper.orderByDesc("create_time");

    List<User> list = userMapper.selectList(wrapper);
    result.put("data",list);
    return result;
}
相关推荐
爬山算法2 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7252 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎2 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄2 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿3 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds3 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹3 小时前
【Java基础】多态 | 打卡day2
java·开发语言
Re.不晚3 小时前
JAVA进阶之路——无奖问答挑战2
java·开发语言
Ro Jace4 小时前
计算机专业基础教材
java·开发语言
mango_mangojuice4 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习