大部分的业务都是crud,可能会遇到切换数据源的问题,可以使用service层的lambdaquery来构建sql语句,例如
xxxService.lambdaquery()
.eq(CollectionUtils.isNotBlank(xxxPO.getUserId())
,xxxPO::getUserId,xxxPO.getUserId());
这样写的话,不用写大量的判断是否为空的情况,前面第一个参数就是条件,如果不为空,那么就会比较userid,这样写看起来清晰很多,还可以用来对时间的校验。
.and(wrap->wrap.le(XXX::getStartDate,new Date())
.ge(xxx:getEndDate,new Date()))
这里是用来比较开始时间小于当前时间,失效时间大于当前时间为有效。
待续。。。