Mybatis-Plus条件构造器的正确使用姿势

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表达式,可以轻松的完成复杂条件拼接;

配合缩进对齐的小技巧,代码瞬间简洁易读,是不是很完美。

  • 14
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值