主页 > 知识库 > oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert

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

热门标签:Linux服务器 地方门户网站 呼叫中心市场需求 铁路电话系统 百度竞价排名 AI电销 服务外包 网站排名优化

最近做项目遇到一个挺纠结的问题,由于业务的关系,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+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266