ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2019-11-23 16:56:15  阅读:335  来源: 互联网

标签:List ids collection 参数 foreach MyBatis id 属性


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。

 

 

 

 

 

 

 

 

 

 

标签:List,ids,collection,参数,foreach,MyBatis,id,属性
来源: https://www.cnblogs.com/xjs1874704478/p/11917351.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有