queryWrapper in查询未加条件,之后的查询条件、排序等不生效

本文介绍了在使用MyBatis的QueryWrapper时,遇到in方法导致的排序orderBy()不生效的问题。当in方法的集合为空时,后续的SQL排序不会被拼接。解决方法是利用in方法的condition条件,确保在集合不为空时才执行in操作,从而保证排序的正确性。

一、queryWrapper排序orderBy()方法不生效

queryWrapper.in(SetMeal::getSetMealType, setMeal.getSetMealTypes());
queryWrapper.orderByAsc(SetMeal::getOrderIndex);

原因:querywrapperin方法在使用时,若集合为空,则之后的sql都不再拼接。
解决方法:用上in方法的condition,添加条件

queryWrapper.in(setMeal.getSetMealTypes() != null && setMeal.getSetMealTypes().size() > 0,SetMeal::getSetMealType, setMeal.getSetMealTypes());
queryWrapper.orderByAsc(SetMeal::getOrderIndex);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值