Mybatis-Plus条件构造器的正确使用姿势
程序员文章站
2022-05-22 20:59:45
...
MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
MP官网(教科书式学习)飞机票:https://mp.baomidou.com/guide/
1. QueryWrapper基础使用
1.1. 天真朴素的写法
QueryWrapper<User> qw = new QueryWrapper<>();
if (StringUtils.isNotBlank(nick)) {
qw.like("nick", nick);
}
if (state != null) {
qw.eq("state", state);
}
return userMapper.selectList(qw);
1.2. 分析API后
AbstractWrapper的条件方法均重载有“是否拼接入SQL”的参数,于是变成了:
QueryWrapper<User> qw = new QueryWrapper<>();
qw.like(StringUtils.isNotBlank(nick), "nick", nick);
qw.eq(state != null, "state", state);
return userMapper.selectList(qw);
1.3. 发现链式调用后
AbstractWrapper的条件方法均返回了原对象,于是可以改为:
return userMapper.selectList(new QueryWrapper<User>()
.like(StringUtils.isNotBlank(nick), "nick", nick)
.eq(state != null, "state", state)
);
1.4. 发现LambdaQueryWrapper后
return userMapper.selectList(new LambdaQueryWrapper<User>()
.like(StringUtils.isNotBlank(nick), User::getNick, nick)
.eq(state != null, User::getState, state)
);
最终成型:此种写法保证了代码简短,并且使用java8的方法引用Entity的Getter方法确保了编译时能正确检查到属性。
2. QueryWrapper条件优先级(条件括号)
面对复杂的sql,如:where nick = ? or(nick like ? and state = ?)
,写法如下:
return userMapper.selectList(new LambdaQueryWrapper<User>()
.eq(User::getNick, nick)
.or(qw -> qw.like(User::getNick, nick)
.eq(User::getState, state)
)
);
融入java8的方法引用和Lambda表达式,可以轻松的完成复杂条件拼接;
配合缩进对齐的小技巧,代码瞬间简洁易读,是不是很完美。
上一篇: 深度优先搜索C++