MyBatis(映射文件中使用foreach标签时报错,属性collection的问题)

Posted 微微亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis(映射文件中使用foreach标签时报错,属性collection的问题)相关的知识,希望对你有一定的参考价值。

org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: org.apache.ibatis.binding.BindingException: Parameter ‘ids‘ not found. Available parameters are [collection, list]
### Cause: org.apache.ibatis.binding.BindingException: Parameter ‘ids‘ not found. Available parameters are [collection, list]

在学习mybatis的时候,使用foreach遍历集合,出现上述一样的错误

接口代码:

    public List<Employee> getEmpsbyCondtionForeach(List<Integer> ids);

xml代码:

    <!--多个id查询信息===id in (1,2,3)-->
    <select id="getEmpsbyCondtionForeach" resultType="emp">
        select * from tbl_employee where id in
        <!-- collection:指定要遍历的集合:
                list类型的参数会特殊处理封装在map中,map的key就是list
             item:将当前遍历出的元素赋值给指定的变量
             separator:每个元素之间的分隔符
             open:遍历出所有结果拼接一个开始的字符
             close:遍历出所有结果拼接一个结束的字符
             index:索引。遍历list的时候是index就是索引,item就是当前值
                         遍历map时index表示的就是map的key,item就是map的值

             #{变量名}就能取出变量值,也就是当前遍历出的元素
         -->
        <foreach collection="id" item="item_id" separator=","
                open="(" close=")">
            #{item_id}
        </foreach>
    </select>

解决方案:

修改mapper.java:

    public List<Employee> getEmpsbyCondtionForeach(@Param("ids") List<Integer> ids);

或者修改mapper.xml:

    <!--多个id查询信息===id in (1,2,3)-->
    <select id="getEmpsbyCondtionForeach" resultType="emp">
        select * from tbl_employee where id in
        <!-- collection:指定要遍历的集合:
                list类型的参数会特殊处理封装在map中,map的key就是list
             item:将当前遍历出的元素赋值给指定的变量
             separator:每个元素之间的分隔符
             open:遍历出所有结果拼接一个开始的字符
             close:遍历出所有结果拼接一个结束的字符
             index:索引。遍历list的时候是index就是索引,item就是当前值
                         遍历map时index表示的就是map的key,item就是map的值

             #{变量名}就能取出变量值,也就是当前遍历出的元素
         -->
        <foreach collection="list" item="item_id" separator=","
                open="(" close=")">
            #{item_id}
        </foreach>
    </select>

原因:

foreach标签的属性collection,在不同的情况下,该属性的值是不一样的,主要有以下3种情况:

1、如果传入的是单参数且参数类型是一个List的时候,collection属性值为list。

2、如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array。

3、如果传入的参数是多个的时候,我们就需要把它们封装成一个Map,当然单参数也可以封装成Map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key。

 

 

 

 

 

 

 

 

 

 

以上是关于MyBatis(映射文件中使用foreach标签时报错,属性collection的问题)的主要内容,如果未能解决你的问题,请参考以下文章

mybatis 最佳实战

Java51Mybatis:两个xml文件的标签,动态sql的if/choose/where/set/foreach标签

mybatis的mapper映射文件中where,if,foreach等的使用

关系映射Web框架 —— 漫长Mybatis学习历程

关系映射Web框架 —— 漫长Mybatis学习历程

MyBatis# foreach标签嵌套使用 if标签时,对象取值问题