• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert

    最近做项目遇到一个挺纠结的问题,由于业务的关系,DB的数据表无法确定,在使用过程中字段可能会增加,这样在insert时给我造成了很大的困扰。

    先来看一下最终我是怎么实现的:

    insert id="batchInsertLine" parameterType="HashMap"> 
       ![CDATA[ 
       INSERT INTO tg_fcst_lines(${lineColumn}) 
       select result.*,sq_fcst_lines.nextval from( 
       ]]> 
       foreach collection="lineList" item="item" index="index" separator="union all" > 
        (select   
        foreach collection="item" index="key" item="_value" separator=","> 
          #{_value} 
        /foreach>  
        from dual) 
       /foreach> 
       ![CDATA[) result]]>   
     /insert> 

    由于数据表不确定,所以我无法确定我要insert的字段,由于是批量insert,确定value值也挺费劲。
    我传给mybatis的参数是一个map:

    Map insertMap = new HashMap(); 
    insertMap.put("lineColumn",lineColumn);    
    insertMap.put("lineList", lineList); 

    lineColumn是一个字符串,lineList是一个list:

    ListMap> lineList = new ArrayList(); 

    lineList里存放的是map,map的键对应数据表的字段,值是你要insert的值,这样就可以通过foreach取出list的值作为insert语句的value,但由于map是无序的,存放的顺序和
    遍历时取值的顺序不一定一致,所以为了确保insert字段和值可以一一对应,可以通过遍历一次map来取出key拼接一个字符串作为insert的字段

    String lineColumn = "";  //拼接的SQL,作为insert语句的一部分 
    [java] view plaincopy
    MapString,String> lineMap = lineList.get(0); 
    for (String key : lineMap.keySet()) { 
      lineColumn +=key+","; 
    } 
    lineColumn +="LINE_ID"; 

    这里的line)id是一个自增的字段,在语句中直接写序列会报错,所以先遍历list将取出的值作为result,在取出result的所有值,连同序列一起作为insert的值。

    在取值的时候使用两个foreace嵌套来实现,外层的foreach遍历list,里层的foreach遍历map。

    以上内容是本文给大家介绍的oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert的全部叙述,希望大家喜欢。

    您可能感兴趣的文章:
    • MyBatis 动态拼接Sql字符串的问题
    • mybatis的动态sql详解(精)
    • MyBatis 执行动态 SQL语句详解
    • Mybatis动态SQL之if、choose、where、set、trim、foreach标记实例详解
    • mybatis动态sql之Map参数的讲解
    • MyBatis动态Sql之if标签的用法详解
    • MyBatis执行动态SQL的方法
    • Mybatis中动态SQL,if,where,foreach的使用教程详解
    • Mybatis模糊查询和动态sql语句的用法
    • Mybatis 动态SQL搭建环境的全过程
    上一篇:日常收集整理oracle trunc 函数处理日期格式(很实用)
    下一篇:Oracle学习记录之使用自定义函数和触发器实现主键动态生成
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert oracle+mybatis,使用,动态,Sql,