随笔缘由:

系统完成到一定程度,少不了要往数据库中添加大量数据进行性能测试。 我用程序做数据10W条,使用jdbc批更新的API,发现每次只能插入2W多条记录。 一番小小研究,觉得总结一下可能有些意义。

总结内容如下:

1:这是我出现问题的代码,插入10W条数据,10W次数据进行一次批处理,发现只能插入24464多条数据,程序也没有报错。

Connection con = (Connection) DriverManager.getConnection(url,user,password); 
 con.setAutoCommit(false); 
 Long startTime = System.currentTimeMillis(); 
 PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
 for (int i = 0; i < list.size(); i++) { 
     KIVResponseBean kivResponseBean=list.get(i);  
     pst.setString(1, kivResponseBean.getK()); 
     pst.setString(2, kivResponseBean.getI()); 
     pst.setInt(3, kivResponseBean.getV()); 
     pst.setInt(4, kivResponseBean.getD()); 
     pst.setString(5, kivResponseBean.getM()); 
     pst.setString(6, kivResponseBean.getR()); 
     pst.addBatch();    
}               
 pst.executeBatch();
 con.commit(); 
 Long endTime = System.currentTimeMillis(); 
 System.out.println("用时:" + (endTime - startTime)); 

2:在不使用批更新时,具体做法就是 不添加这句代码 con.setAutoCommit(false); 并且每次为SQL指定参数后就执行 pst.executeUpdate(); 提交数据;结果10W条记录插入成功,但是使用了 35833ms的时间消耗。

Class.forName("oracle.jdbc.driver.OracleDriver"); 
 Connection con = (Connection) DriverManager.getConnection(url,user,password); 
 Long startTime = System.currentTimeMillis(); 
 PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
 for (int i = 0; i < list.size(); i++) { 
     KIVResponseBean kivResponseBean=list.get(i);  
     pst.setString(1, kivResponseBean.getK()); 
     pst.setString(2, kivResponseBean.getI()); 
     pst.setInt(3, kivResponseBean.getV()); 
     pst.setInt(4, kivResponseBean.getD()); 
     pst.setString(5, kivResponseBean.getM()); 
     pst.setString(6, kivResponseBean.getR()); 
     pst.executeUpdate();
}               
 Long endTime = System.currentTimeMillis(); 
 System.out.println("用时:" + (endTime - startTime));

3:使用批更新,并且制定没10000次提交一次更新,此时 使用时间 2980 ms ,10w条数据也批量添加成功,oracle对每次执行的批更新有限制,我在11g的环境下测试 在2W4K多,网上有朋友说在10g下 每次提交1W多数据就会报错。

Class.forName("oracle.jdbc.driver.OracleDriver"); 
Connection con = (Connection) DriverManager.getConnection(url,user,password); 
con.setAutoCommit(false); 
Long startTime = System.currentTimeMillis(); 
PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
int batchCount=list.size()/batchSize+1;
for(int batch=0;batch<batchCount;batch++) {
    for (int i = batch*batchSize; (i <(batch+1)*batchSize)&&(i<list.size()); i++) { 
        KIVResponseBean kivResponseBean=list.get(i);  
        pst.setString(1, kivResponseBean.getK()); 
        pst.setString(2, kivResponseBean.getI()); 
        pst.setInt(3, kivResponseBean.getV()); 
        pst.setInt(4, kivResponseBean.getD()); 
        pst.setString(5, kivResponseBean.getM()); 
        pst.setString(6, kivResponseBean.getR()); 
        pst.addBatch();    
   }               
    pst.executeBatch();
    con.commit(); 
    pst.clearBatch();
}
Long endTime = System.currentTimeMillis(); 
System.out.println("用时:" + (endTime - startTime)); 

随笔缘由:

系统完成到一定程度,少不了要往数据库中添加大量数据进行性能测试。 我用程序做数据10W条,使用jdbc批更新的API,发现每次只能插入2W多条记录。 一番小小研究,觉得总结一下可能有些意义。

总结内容如下:

1:这是我出现问题的代码,插入10W条数据,10W次数据进行一次批处理,发现只能插入24464多条数据,程序也没有报错。

Connection con = (Connection) DriverManager.getConnection(url,user,password); 
 con.setAutoCommit(false); 
 Long startTime = System.currentTimeMillis(); 
 PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
 for (int i = 0; i < list.size(); i++) { 
     KIVResponseBean kivResponseBean=list.get(i);  
     pst.setString(1, kivResponseBean.getK()); 
     pst.setString(2, kivResponseBean.getI()); 
     pst.setInt(3, kivResponseBean.getV()); 
     pst.setInt(4, kivResponseBean.getD()); 
     pst.setString(5, kivResponseBean.getM()); 
     pst.setString(6, kivResponseBean.getR()); 
     pst.addBatch();    
}               
 pst.executeBatch();
 con.commit(); 
 Long endTime = System.currentTimeMillis(); 
 System.out.println("用时:" + (endTime - startTime)); 

2:在不使用批更新时,具体做法就是 不添加这句代码 con.setAutoCommit(false); 并且每次为SQL指定参数后就执行 pst.executeUpdate(); 提交数据;结果10W条记录插入成功,但是使用了 35833ms的时间消耗。

Class.forName("oracle.jdbc.driver.OracleDriver"); 
 Connection con = (Connection) DriverManager.getConnection(url,user,password); 
 Long startTime = System.currentTimeMillis(); 
 PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
 for (int i = 0; i < list.size(); i++) { 
     KIVResponseBean kivResponseBean=list.get(i);  
     pst.setString(1, kivResponseBean.getK()); 
     pst.setString(2, kivResponseBean.getI()); 
     pst.setInt(3, kivResponseBean.getV()); 
     pst.setInt(4, kivResponseBean.getD()); 
     pst.setString(5, kivResponseBean.getM()); 
     pst.setString(6, kivResponseBean.getR()); 
     pst.executeUpdate();
}               
 Long endTime = System.currentTimeMillis(); 
 System.out.println("用时:" + (endTime - startTime));

3:使用批更新,并且制定没10000次提交一次更新,此时 使用时间 2980 ms ,10w条数据也批量添加成功,oracle对每次执行的批更新有限制,我在11g的环境下测试 在2W4K多,网上有朋友说在10g下 每次提交1W多数据就会报错。

Class.forName("oracle.jdbc.driver.OracleDriver"); 
Connection con = (Connection) DriverManager.getConnection(url,user,password); 
con.setAutoCommit(false); 
Long startTime = System.currentTimeMillis(); 
PreparedStatement pst = (PreparedStatement) con.prepareStatement(sql.toString()); 
int batchCount=list.size()/batchSize+1;
for(int batch=0;batch<batchCount;batch++) {
    for (int i = batch*batchSize; (i <(batch+1)*batchSize)&&(i<list.size()); i++) { 
        KIVResponseBean kivResponseBean=list.get(i);  
        pst.setString(1, kivResponseBean.getK()); 
        pst.setString(2, kivResponseBean.getI()); 
        pst.setInt(3, kivResponseBean.getV()); 
        pst.setInt(4, kivResponseBean.getD()); 
        pst.setString(5, kivResponseBean.getM()); 
        pst.setString(6, kivResponseBean.getR()); 
        pst.addBatch();    
   }               
    pst.executeBatch();
    con.commit(); 
    pst.clearBatch();
}
Long endTime = System.currentTimeMillis(); 
System.out.println("用时:" + (endTime - startTime)); 

JDBC更新10W级以上数据性能优化相关推荐

  1. 关系型数据库大数据性能优化解决方案之:分表(当前表历史表)、表分区、数据清理原则

    原因和目的 由于交易量大或者日积月累造成数据库的数据量越来越大.会导致系统性能大幅下降,所以要对部分业务的表数据作备份和清理 减少数据量,来提升请求响应的速度,提升用户体验 数据是否需要清理的阀值判断 ...

  2. Oracle数据性能优化

    Oracle 应用系统的优化四个方面 1. 应用程序SQL语句优化; 2. ORACLE数据库参数调整; 3. 操作系统参数调整; 4. 网络性能调整. oracle应用系统的性能指标 1. 数据库吞 ...

  3. 【Elasticsearch】es 插入数据 性能优化 以及 影响插入的因素

    1.概述 2.性能优化 3. 性能降低 3.1 插入数据时对索引进行预排序 Index sorting (索引排序)可用于在插入时对索引进行预排序,而不是在查询时再对索引进行排序,这将提高范围查询(r ...

  4. 转载--批量更新数据(性能优化)

    最近做的游戏,上线后出了不少问题,所以我就经常去查数据库数据,翻各种日志等,但是在查询的时候发现好蛋疼,有些地方的时间是写 "2016-08-11 20:13:02"这种格式,有些 ...

  5. ElasticSearch 亿级数据检索深度性能优化

    一.前言 数据平台已迭代三个版本,从头开始遇到很多常见的难题,终于有片段时间整理一些已完善的文档,在此分享以供所需朋友的实现参考,少走些弯路,在此篇幅中偏重于ES的优化,关于HBase,Hadoop的 ...

  6. Mysql 批量写入数据 性能优化

    2019独角兽企业重金招聘Python工程师标准>>> 测试环境 配置直接影响执行速度,先上一下测试机配置: cpu i7 5500U(低电压伤不起,以后再也不买低电压的U了) 内存 ...

  7. bulk Java提交数据,性能优化 – bulk提交 - ELK Stack 中文指南

    在 CRUD 章节,我们已经知道 ES 的数据写入是如何操作的了.喜欢自己动手的读者可能已经迫不及待的自己写了程序开始往 ES 里写数据做测试.这时候大家会发现:程序的运行速度非常一般,即使 ES 服 ...

  8. MySql千万级表性能优化

    近期在处理一个千万级表数据的优化措施与总结(不考虑硬件方面): 1)数据库做主从,读写分离 2)表结构把不常用的字段列移入附加表 3)查询语句优化,避免全表扫描,. 4)按需合理增加索引 5)做分区 ...

  9. iMobile中三维数据的性能优化

    作者:xinxin 目前,很多项目都用SuperMap iMobile for Android产品来实现展示三维数据效果,但由于三维数据对硬件设备要求高,而移动端设备的硬件远不如PC端,所以想要在iM ...

  10. 分布式专题-数据库分库分表之Mycat01-数据库性能优化方案

    目录导航 前言 为什么要分库分表 数据库性能瓶颈主要原因 数据性能优化方案 SQL 与索引 表与存储引擎 架构 配置 操作系统与硬件 架构演进与分库分表 单应用单数据库 多应用单数据库 多应用独立数据 ...

最新文章

  1. 用原始方法解析复杂字符串,json一定要用JsonMapper么?
  2. python制作ios游戏_python自动化生成IOS的图标
  3. 整数数组的定义,然后输入一个整数X,假定X不在这个数组,返回小于X位置的最大数目i而超过X位置的最小数目j...
  4. jQuery 下拉框应用 拓展
  5. 【Python-ML】SKlearn库集成学习器Bagging
  6. gerber文件怎么导贴片坐标_PCBA贴片加工厂家的上机贴片编程
  7. Maven项目整合提示:Maven Missing artifact xxx:jar 错误解决方案
  8. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-演示使用报表构建UI-入库业务查询模块...
  9. SAP License:什么是ERP供应链
  10. Jupyter Lab的学习笔记
  11. pyjion python3.6_[新闻] CPython / 微软 Pyjion / IBM Python+OMR
  12. Mybatis JPA-集成方案+代码解析
  13. MySQL基于日志还原数据
  14. Spark SQL将rdd转换为数据集-以编程方式指定模式(Programmatically Specifying the Schema)
  15. 分布式文件系统FastDFS动态扩容
  16. sqlmap 基本使用教程--个人笔记
  17. Excel员工考勤表模板,这三套送给您
  18. 盘点服装进销存软件和生产进销存软件排行榜
  19. [4G5G专题-27]:架构-UE终端的4G+5G双连接详解
  20. 计算机基础网络空间安全,网络空间安全学院“首届计算机基础知识竞赛”圆满结束...

热门文章

  1. 每周更新:Element、Vant新版本更新、IntelliJ IDEA 2019.1 发布 RC 候选版、企业级 UI 设计语言Ant Design 3.15.2 发布
  2. 16kb等于多少b_一篇文章讲透MySQL为什么要用B+树实现索引
  3. 专题八:MATLAB图形用户界面设计
  4. MySQL的select语法
  5. Yii Framework2.0开发教程(5)数据库mysql函数
  6. c语言多次调用函数 只给出最后一次,一个方法连续调用多次,但方法体里面的代码只保证最后一次的执行,之前连续调用的方法体都不执行...
  7. LINUX编译mate-desktop/pluma-1.26.0文本编辑器
  8. /usr/include/openssl/des.h:91:9: error: unknown type name ‘DES_LONG’ DES_LONG deslong[2];
  9. 跟人合作人工智能,方案没有,钱又不出,这怎么合作?
  10. lua.c:82:10: fatal error: readline/readline.h: 没有那个文件或目录