zoukankan      html  css  js  c++  java
  • Mybatis 中遍历map 参数中的 list 和 array 属性

    原文:https://blog.csdn.net/liudongdong0909/article/details/51048835

    问题
    在项目有中遇到批量删除操作时,需要根据两个属性去删除数据,其中一个是类型:type, 另一个是ids:数组形式的id数组。由于在官方文档中只是简单的介绍foreach的用法,套用之后进行批量删除操作:提示遍历map中的array 属性是无法获取值。

    解决方案
    通过重新阅读mybatis 3 官方文档, 查阅CSDN iteye等网站资料。

    代码
    controller层

    /**
     *[根据附件的类型 type 和 对象ids批量删除附件信息]
     */
    @RequestMapping("/deleteProjectInterimByIds.do")
    public void deleteProjectInterimByIds(HttpServletResponse response, 
    @RequestParam(value = "ids", required=true)Long[] ids,
    @RequestParam(value="type",required=true)Integer type) {
            Map<String, Object> paraMap = new HashMap<String, Object>();
            paraMap.put("type", type);
            paraMap.put("ids", ids);
            int i =  nterimAttService.deleteAttachmentByObjIdsAndType(paraMap);
            System.out.println(i);

    dao层

    @Override
    public int deleteAttachmentByObjIdsAndType(Map<String, Object> paraMap) {
        return this.getSqlSession().delete(NAME_SPACE +"batchDeleteAttByIds", paraMap);
        }

    mapper.xml

    <–1.取map中的key 为type的值 
    2.取map中的key 为ids 的值;Ids 在map中是以数组的形式存在 的,直接标记取出就可以,采用#{des}的方式会出现错误;–>

    <delete id="batchDeleteAttByIds" parameterType="map">
        delete from project_attachments
        where attachment_type = #{type} and object_id in 
        <foreach collection="ids" open="(" close=")" separator="," item="id">
            #{id}
        </foreach> 
      </delete>
  • 相关阅读:
    C平衡二叉树(AVL)创建和删除
    C格式字符串转为二叉树
    C前序遍历二叉树Morris Traversal算法
    C单链表操作
    C仿黑白棋版XO棋
    C传递参数给main函数
    C图形化第一步
    Perl看完这个,再不敢说自己会玩贪吃蛇
    Perl寻路A*算法实现
    C字符贪吃蛇
  • 原文地址:https://www.cnblogs.com/shihaiming/p/10370409.html
Copyright © 2011-2022 走看看