码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2019-11-23 18:08:22      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:java   python   for   bat   available   employee   情况下   apach   div   

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的问题)

标签:java   python   for   bat   available   employee   情况下   apach   div   

原文地址:https://www.cnblogs.com/xjs1874704478/p/11917351.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!