首先,先看代码示例:
List<Entity> list = testService.list(
new LambdaQueryWrapper<Entity>()
.eq(ObjectUtils.isNotEmpty(req.getParam()),Entity::getParam,
req.getParam().substring(0,7).replace("-",""))
);
正常逻辑,当ObjectUtils.isNotEmpty(req.getParam())为false的时候,所执行的SQL不会出现当前条件的字段;
然而,这种写法如果当req.getParam()为""的时候,程序会出现数组下标越界的错误,虽然前面条件未成立,但是后面的代码依然编译执行;
此处是本猿自己工作中遇到的一些小问题,发表出来,以便记录,也给路过的伙伴提个醒.