循环拼接如何实现
可以实现循环的内容拼接
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=“非常好玩”