问题描述
在 MyBatis XML 中尝试以下代码时出错。这是我选择查询的一部分, 其中拉水果价格。水果名称应该是APPLE,并且应该属于水果列表。
<if test="@org.apache.commons.collections.CollectionUtils@exists(param.getFruitList(),n -> n.equals('APPLE'))">
tbl.price
</if>
下面是我得到的错误。
调用@handleDefaultException方法:由:org.mybatis.spring.MyBatisSystemException:嵌套异常为org.apache.ibatis.builder.BuilderException:错误评估表达式'@org.apache.commons.collections.CollectionUtils@exists() )'。原因:org.apache.ibatis.ognl.ExpressionSyntaxException:OGNL 表达式格式错误:@org.apache.commons.collections.CollectionUtils@exists
解决方法
我的理解是 MyBatis 的 XML 表达式解析器无法处理 lambdas/method 引用。您可以尝试创建一个辅助方法,例如
public static boolean helper(List<String> l) {
return CollectionUtils.exists(l,"APPLE"::equals);
}
然后在 XML 中引用它:
<if test="@some.package.Utils@helper(param.getFruitList())">
tbl.price
</if>