先上代码:

controller:

result = service.insertTRbXdhjLendYdData(params);

service:

        List<TRbXdhjLendDTO> dtoList = (List<TRbXdhjLendDTO>) paramMap.get("jsonList");
//批量插入
dao.insertYdData(dtoList);

dao:

    /**
* 存储从工厂库抽取的易贷数据的放款信息
* @param paramMap
* @return
*/
public int insertYdData(List<TRbXdhjLendDTO> list);

mapper:

    <!-- 插入从工厂抽取的易贷数据的放款计划信息  -->
<insert id="insertYdData" parameterType="java.util.List">
insert into t_rb_xdhj_lend
(
id ,
submit_date ,
company_no ,
company_name ,
rgu_org_id ,
rgu_org_name ,
version ,
source_code ,
batch_num ,
loan_code ,
loan_start_time ,
loan_end_time ,
loan_name ,
user_idcard ,
user_idcard_hash ,
loan_use ,
type ,
loan_describe ,
amount ,
rate ,
term_type ,
term ,
pay_type ,
service_cost ,
risk_margin ,
loan_type ,
collateral_desc ,
create_user_id ,
create_date ,
validate_state ,
corporation_id ,
send_time ,
remark ,
product_code
)
select seq_SYS_APP_ERROR_INFO.nextval id,A.* from(
<foreach collection="list" item="dto" index="index" separator="UNION">
select
#{dto.submitDate,jdbcType=DATE} submit_date
,#{dto.companyNo,jdbcType=VARCHAR} company_no
,#{dto.companyName,jdbcType=VARCHAR} company_name
,#{dto.rguOrgId,jdbcType=DECIMAL} rgu_org_id
,#{dto.rguOrgName,jdbcType=VARCHAR} rgu_org_name
,#{dto.version,jdbcType=VARCHAR} version
,#{dto.sourceCode,jdbcType=VARCHAR} source_code
,#{dto.batchNum,jdbcType=VARCHAR} batch_num
,#{dto.loanCode,jdbcType=VARCHAR} loan_code
,#{dto.loanStartTime,jdbcType=VARCHAR} loan_start_time
,#{dto.loanEndTime,jdbcType=VARCHAR} loan_end_time
,#{dto.loanName,jdbcType=VARCHAR} loan_name
,#{dto.userIdcard,jdbcType=VARCHAR} user_idcard
,#{dto.userIdcardHash,jdbcType=VARCHAR} user_idcard_hash
,#{dto.loanUse,jdbcType=VARCHAR} loan_use
,#{dto.type,jdbcType=VARCHAR} type
,#{dto.loanDescribe,jdbcType=VARCHAR} loan_describe
,#{dto.amount,jdbcType=VARCHAR} amount
,#{dto.rate,jdbcType=VARCHAR} rate
,#{dto.termType,jdbcType=VARCHAR} term_type
,#{dto.term,jdbcType=VARCHAR} term
,#{dto.payType,jdbcType=VARCHAR} pay_type
,#{dto.serviceCost,jdbcType=VARCHAR} service_cost
,#{dto.riskMargin,jdbcType=VARCHAR} risk_margin
,#{dto.loanType,jdbcType=VARCHAR} loan_type
,#{dto.collateralDesc,jdbcType=VARCHAR} collateral_desc
,#{dto.createUserId,jdbcType=DECIMAL} create_user_id
,systimestamp create_date
,'1' validate_state
,#{dto.corporationId,jdbcType=DECIMAL} corporation_id
,#{dto.sendTime,jdbcType=TIMESTAMP} send_time
,#{dto.remark,jdbcType=VARCHAR} remark
,#{dto.productCode,jdbcType=VARCHAR} product_code
from dual
</foreach>
) A
</insert>

1、新增的数据含有ORACLE自增长序列;
2、union all 会报ORA:02287-此处不允许序号;

oracle结合mybatis批量插入数据的更多相关文章

  1. mybatis批量插入数据到oracle

    mybatis 批量插入数据到oracle报 ”java.sql.SQLException: ORA-00933: SQL 命令未正确结束“  错误解决方法 oracle批量插入使用 insert a ...

  2. Mybatis 批量插入数据

    --mybatis 批量插入数据 --1.Oracle(需要测试下是否支持MySQL) < insert id ="insertBatch" parameterType=&q ...

  3. 【转载】MyBatis批量插入数据(insert)

    介绍:MyBatis批量插入数据,原理就是在xml文件中添加 foreach 语句,然后MyBatis自动在values后面添加多个括号: XML文件如下: <?xml version=&quo ...

  4. mybatis批量插入数据

    Mybatis在执行批量插入时,如果使用的是for循环逐一插入,那么可以正确返回主键id.如果使用动态sql的foreach循环,那么返回的主键id列表,可能为null,这让很多人感到困惑:本文将分析 ...

  5. MyBatis批量插入数据(MySql)

    由于项目需要生成多条数据,并保存到数据库当中,在程序中封装了一个List集合对象,然后需要把该集合中的实体插入到数据库中,项目使用了Spring+MyBatis,所以打算使用MyBatis批量插入,应 ...

  6. MyBatis 批量插入数据的 3 种方法!

    批量插入功能是我们日常工作中比较常见的业务功能之一,之前我也写过一篇关于<MyBatis Plus 批量数据插入功能,yyds!>的文章,但评论区的反馈不是很好,主要有两个问题:第一,对 ...

  7. 160421、MyBatis批量插入数据

    在程序中封装了一个List集合对象,然后需要把该集合中的实体插入到数据库中,由于项目使用了Spring+MyBatis的配置,所以打算使用MyBatis批量插入,由于之前没用过批量插入,在网上找了一些 ...

  8. 基于Oracle的Mybatis 批量插入

    项目中会遇到这样的情况,一次性要插入多条数据到数据库中,有两种插入方法: 方法一: Mybatis本身只支持逐条插入,比较笨的方法,就是遍历一个List,循环中逐条插入,比如下面这段代码 for(Da ...

  9. MyBatis 批量插入数据对插入记录数的限制

    <基于 MyBatis 框架的批量数据插入的性能问题的探讨>(作者:魏静敏 刘欢杰 来源:<计算机光盘软件与应用> 2013 年第 19 期)中提到批量插入的记录数不能超过10 ...

随机推荐

  1. 算法进阶面试题02——BFPRT算法、找出最大/小的K个数、双向队列、生成窗口最大值数组、最大值减最小值小于或等于num的子数组数量、介绍单调栈结构(找出临近的最大数)

    第二课主要介绍第一课余下的BFPRT算法和第二课部分内容 1.BFPRT算法详解与应用 找到第K小或者第K大的数. 普通做法:先通过堆排序然后取,是n*logn的代价. // O(N*logK) pu ...

  2. spring整合mybatisXML版

    引用的所有jar包,本demo是一个普通的java项目测试的: aopalliance.jarasm-3.3.1.jaraspectjweaver.jarcglib-2.2.2.jarcommons- ...

  3. Windows 修改host文件

    在实际的开发中,有时我们会修改windows的hosts文件,达到指定域名映射到指定ip上的功能.修改方式如下: 1. windows 中hosts文件位置(win10): C:\Windows\Sy ...

  4. Bootstrap 图片

    摘要: Bootstrap框架对图片样式的支持. <img>类 Bootstrap 提供了对图片应用简单样式的 class. .img-rounded:添加 border-radius:6 ...

  5. Django 面向对象orm

    django支持三种风格的模型继承: 1. 抽象类继承: 父类继承自models.Model, 但不会在数据库中生成相应的数据表.父类的属性列存储在其子类的数据表中 2. 多表继承: 多表继承的每个类 ...

  6. [POI2011]Śmieci

    [POI2011]Śmieci 题目大意: 一个\(n(n\le10^5)\)个点\(m(m\le10^6)\)条边的无向图,每条边有边权\(0/1\),试找出若干个环,使得每次翻转环上所有边的权值, ...

  7. Docker 容器生命周期管理命令

    docker run 命令 -d: 后台运行容器,并返回容器ID: -i: 以交互模式运行容器,通常与 -t 同时使用: -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用: --name= ...

  8. WPF应用Access数据库

    WPF应用Access数据库 现在Access数据库中有表GuestTable,其中的字段如下图所示,现在需要应用WPF技术为此表制作一个数据库管理窗口,实现对此数据库中的数据进行数据的增.删.改和查 ...

  9. Linux 下建立 Git 与 GitHub 的连接

    Git 是一款开源的分布式版本控制系统,而 GitHub 是依托 Git 的代码托管平台. GitHub 利用 Git 极其强大的克隆和分支功能,使得社区成员能够自由地参与到开源项目中去. 不过,在开 ...

  10. spring cloud: 使用consul来替换config server

    上一篇提到了,eureka 2.x官方停止更新后,可以用consul来替代,如果采用consul的话,其实config server也没必要继续使用了,consul自带kv存储,完全可以取代confi ...