Mybatis Plus and 按多字段查询(超详细)
一则或许对你有用的小广告
欢迎加入小哈的星球 ,你将获得:专属的项目实战 / Java 学习路线 / 一对一提问 / 学习打卡/ 赠书活动
目前,正在
星球
内带小伙伴们做第一个项目:全栈前后端分离博客项目,采用技术栈 Spring Boot + Mybatis Plus + Vue 3.2 + Vite 4
,手把手,前端 + 后端全栈开发,从 0 到 1 讲解每个功能点开发步骤,1v1 答疑,陪伴式直到项目上线,目前已更新了 144 小节,累计 22w+ 字,讲解图:923 张,还在持续爆肝中,后续还会上新更多项目,目标是将 Java 领域典型的项目都整上,如秒杀系统、在线商城、IM 即时通讯、权限管理等等,已有 440+ 小伙伴加入,欢迎点击围观
。
前言
大家好,我是小哈。
本小节中给大家讲解如何通过 Mybatis Plus 中的 Wrapper 组装 SQL 实现按多字段查询。
方法
Wrapper 条件构造器中 and
相关的方法如下:
// params : key 为数据库字段名, value 为字段值
allEq(Map<R, V> params)
// null2IsNull : 为 true 则在 map 的 value 为 null 时调用 isNull 方法,为 false 时则忽略 value 为null的
allEq(Map<R, V> params, boolean null2IsNull)
allEq(boolean condition, Map<R, V> params, boolean null2IsNull)
// filter : 过滤函数,是否允许字段传入比对条件中
allEq(BiPredicate<R, V> filter, Map<R, V> params)
// 同上
allEq(BiPredicate<R, V> filter, Map<R, V> params, boolean null2IsNull)
allEq(boolean condition, BiPredicate<R, V> filter, Map<R, V> params, boolean null2IsNull)
代码示例
allEq
方法是父类 AbstractWrapper
(抽象类)中定义的方法,子类 QueryWrapper
、UpdateWrapper
均可调用,以下用 QueryWrapper
来演示:
// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
// and 语句
Map<String, Object> map = new HashMap();
map.put("name", "犬小哈");
map.put("age", null);
wrapper.allEq(map);
// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (name = '犬小哈' AND age IS NULL)
userMapper.selectList(wrapper);
// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
// and 语句
Map<String, Object> map = new HashMap();
map.put("name", "犬小哈");
map.put("age", null);
// null2IsNull 设置为 false 时,为空的字段不会被组装到 where 条件中
wrapper.allEq(map, false);
// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (name = '犬小哈')
userMapper.selectList(wrapper);
// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
// and 语句
Map<String, Object> map = new HashMap();
map.put("name", "犬小哈");
map.put("age", 30);
map.put("gender", null);
// 添加过滤函数,k 代表字段名,只查询字段名包含 a 字母的字段
wrapper.allEq((k, v) -> k.contains("a"), map);
// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (name = '犬小哈' AND age = 30)
userMapper.selectList(wrapper);