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

Consumer> 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=“非常好玩”

你可能感兴趣的:(java,前端,javascript)