zoukankan      html  css  js  c++  java
  • mybatis批量操作问题总结

    1、mybatis接受list参数问题

    http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach里有一段说明:

    写道
    注意 你可以传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时 候,MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键。

    因为我传的参数只有一个,而且传入的是一个List集合,所以mybatis会自动封装成Map<"list",studentNameList>。在解析的时候会通过“list”作为Map的key值去寻找。但是我在xml中却声明成studentNameList了,所以自然会报错找不到。

    解决办法:

    第一种就是修改mapper.xml中foreach标签内容,把studentNameList修改为list

    Xml代码  收藏代码
    1. <if test="list != null">  
    2.     AND student_name in  
    3.     <foreach collection="list" item="item" open="(" separator="," close=")">  
    4.         #{item}   
    5.     </foreach>  
    6. </if>  

    不过这种方式我个人不太建议,因为以后如果要扩展该方法,增加集合参数的时候,还得修改xml中的内容。

    第二种方式,修改dao中的参数传入方式,手动封装成map,然后把map当参数传进去

    Dao方法修改为:

    Java代码  收藏代码
    1. public int getStudentCount(List<String> studentNameList){  
    2.     //把参数手动封装在Map中  
    3.     Map<String, Object> map = new HashMap<String, Object>();  
    4.     map.put("studentNameList", studentNameList);  
    5.     return super.count("getStudentCount", map);  
    6. }  

    然后修改mapper.xml中的parameterType类型为Map

    Xml代码  收藏代码
    1. <!--注意下面的parameterType类型必须修改为Map类型,foreach中引用的List名称不用改变-->  
    2. <select id="Student.getStudentCount" parameterType="java.util.Map" resultType="java.lang.Integer">  
    3.     <![CDATA[ 
    4.     SELECT 
    5.         COUNT(*) 
    6.     FROM 
    7.         t_student WHERE 1=1  
    8.     ]]>  
    9.     <if test="studentNameList != null">  
    10.         AND student_name in  
    11.         <foreach collection="studentNameList" item="item" open="(" separator="," close=")">  
    12.             #{item}   
    13.         </foreach>  
    14.     </if>  
    15. </select>  

    修改完后,重新执行了一下测试用例,测试通过。

    2、同时执行多条语句问题

    <!-- 批量更新 -->
    <update id="updatePL" parameterType = "java.util.List">
    <foreach collection="list" item="item" index="idx" separator=";" >
    UPDATE t_mortgage_applay
    <set>
    mortgage_contract_id = #{item.mortgageContractId},
    applay_type = #{item.applayType},
    start_time = #{item.startTime},
    end_time = #{item.endTime},
    status = #{item.status},
    remarks = #{item.remarks},
    update_by = #{item.updateBy.id},
    update_date = #{item.updateDate},
    organ_id = #{item.organId},
    proc_ins_id = #{item.procInsId},
    audit_type = #{item.auditType}
    </set>
    WHERE id = #{item.id}
    </foreach>
    </update>

    注:jdbc.url=jdbc:mysql://127.0.0.1:3306/fpd_qh_test?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true      需要&allowMultiQueries=true才可以支持多条语句同时执行

  • 相关阅读:
    20169215 缓冲区溢出漏洞实验
    20169215 2016-2017-2 实验二Nmap的使用与分析
    20169215 2016-2017-2 《网络攻防实践》/《网络攻击与防范》第八周学习总结
    Numpy Usage Introduction
    [Example of Sklearn]
    [Example of Sklearn]
    [Example of Sklearn]
    [Scikit-Learn]
    [Scikit-Learn]
    [Scikit-Learn]
  • 原文地址:https://www.cnblogs.com/lengzhijun/p/5948667.html
Copyright © 2011-2022 走看看