0

我对 MyBatis 有一个小问题。我正在尝试遍历 Hashmap,但似乎 MyBatis 无法做到这一点。Hshmap 的名称是 serviceMap。这是 MyBatis foreach 的代码:

<foreach item="item" index="key" collection="serviceMap"  open="(" separator="or" close=")">
                (upper(p.ENDPOINT) like upper(#{key})
                and
                upper(p.ENDPOINT_OPERATION) like upper(#item))
</foreach>

例外是:

org.apache.ibatis.builder.BuilderException: Error evaluating expression 'serviceMap'. Return value ({vehicle=register}) was not iterable.
at org.apache.ibatis.builder.xml.dynamic.ExpressionEvaluator.evaluateIterable(ExpressionEvaluator.java:59)
at org.apache.ibatis.builder.xml.dynamic.ForEachSqlNode.apply(ForEachSqlNode.java:51)
at org.apache.ibatis.builder.xml.dynamic.MixedSqlNode.apply(MixedSqlNode.java:29)
at org.apache.ibatis.builder.xml.dynamic.IfSqlNode.apply(IfSqlNode.java:31)
at org.apache.ibatis.builder.xml.dynamic.MixedSqlNode.apply(MixedSqlNode.java:29)

是 MyBatis 根本无法做到还是我犯了错误?

如果有人可以帮助我,那就太好了。

非常感谢!斯特凡

4

2 回答 2

2

HashMap 是不可迭代的。您需要迭代 entrySet。

<foreach item="item" index="key" collection="serviceMap.entrySet"  open="(" separator="or" close=")">
            (upper(p.ENDPOINT) like upper(#{key})
            and
            upper(p.ENDPOINT_OPERATION) like upper(#item))

于 2013-09-17T12:28:35.627 回答
0
<foreach item="item" index="key" collection="serviceMap.entrySet()" open="((" separator="),(" close="))">
                (upper(p.ENDPOINT) like upper(#{item.key})
                and
                upper(p.ENDPOINT_OPERATION) like upper(#item.value))
</foreach>

使用精确的 hashmap 机制

于 2017-09-07T05:50:17.633 回答