MyBatis使用foreach迭代hashmap

时间:2013-09-04 10:05:47

标签: mybatis

我的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根本无法做到这一点,还是我犯了错误?

如果有人可以帮助我,那将是非常好的。

非常感谢! 斯蒂芬

2 个答案:

答案 0 :(得分:2)

HashMap不可迭代。 You need to iterate the 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))

答案 1 :(得分: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机制