mybatise plus and中同时包含几个or查询时候需要循环拼接如何使用

循环拼接如何实现

可以实现循环的内容拼接

 queryWrapper.and(s-> {
                for (String expertIn:dto.getAllExpertIn()) {
                     s.or(w->{
                         w.like(UtilObj.isNotEmpty(expertIn),"t_experts."+Experts.F_EXPERT_IN,expertIn);
                     });
                }
            });

产生的sql如下:这样就可以使用循环去拼接sql语句了
AND ((
t_experts.F_EXPERT_IN LIKE ‘%5%’
)
OR ( t_experts.F_EXPERT_IN LIKE ‘%7%’ )
OR ( t_experts.F_EXPERT_IN LIKE ‘%6%’ ))

and和or的语句处理 Consumer

Consumer<QueryWrapper<>>
还有一点,其实我是想怎么才能把一个查询用括号给他扩住,以至于他是和别的部分共同进行组合,因为在拼接sql语句的时候这样会更方便一些

Consumer<QueryWrapper<RelaxTrain>> consumer =qw->{
  qw.eq(RelaxTrain.F_GAME_NAME,"小游戏A");
  qw.or();
  qw.eq(RelaxTrain.F_GAME_NAME,"小游戏B");
};
queryWrapper.and(consumer);
queryWrapper.eq(RelaxTrain.F_GAME_INTRODUCTION,"非常好玩");

这样就相当于单独使用一个括号给他把前面的or查询扩起来,然后和后面的做and查询

where (F_GAME_NAME=“小游戏A” or F_GAME_NAME=“小游戏B” ) and F_GAME_INTRODUCTION=“非常好玩”

如果不用 Consumer直接.or()的时候 sql语句就会变成这样:
where F_GAME_NAME=“小游戏A” or F_GAME_NAME=“小游戏B” and F_GAME_INTRODUCTION=“非常好玩”

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值