使用jdbc向数据库插入100000条记录,分别使用statement,PreparedStatement,及PreparedStatement+批处理3种方式进行测试:

  1. public void exec(Connection conn){
  2. try {
  3. //开始时间
  4. Long beginTime = System.currentTimeMillis();
  5. //设置手动提交
  6. conn.setAutoCommit(false);
  7. Statement st = conn.createStatement();
  8. for(int i=0;i<100000;i++){
  9. String sql="insert into t1(id) values ("+i+")";
  10. st.executeUpdate(sql);
  11. }
  12. //结束时间
  13. Long endTime = System.currentTimeMillis();
  14. System.out.println("st:"+(endTime-beginTime)/1000+"秒");//计算时间
  15. st.close();
  16. conn.close();
  17. } catch (SQLException e) {
  18. e.printStackTrace();
  19. }
  20. }

//2.使用PreparedStatement对象

  1. public void exec2(Connection conn){
  2. try {
  3. Long beginTime = System.currentTimeMillis();
  4. conn.setAutoCommit(false);//手动提交
  5. PreparedStatement pst = conn.prepareStatement("insert into t1(id) values (?)");
  6. for(int i=0;i<100000;i++){
  7. pst.setInt(1, i);
  8. pst.execute();
  9. }
  10. conn.commit();
  11. Long endTime = System.currentTimeMillis();
  12. System.out.println("pst:"+(endTime-beginTime)/1000+"秒");//计算时间
  13. pst.close();
  14. conn.close();
  15. } catch (SQLException e) {
  16. e.printStackTrace();
  17. }
  18. }

//3.使用PreparedStatement + 批处理

  1. public void exec3(Connection conn){
  2. try {
  3. conn.setAutoCommit(false);
  4. Long beginTime = System.currentTimeMillis();
  5. //构造预处理statement
  6. PreparedStatement pst = conn.prepareStatement("insert into t1(id) values (?)");
  7. //1万次循环
  8. for(int i=1;i<=100000;i++){
  9. pst.setInt(1, i);
  10. pst.addBatch();
  11. //每1000次提交一次
  12. if(i%1000==0){//可以设置不同的大小;如50,100,500,1000等等
  13. pst.executeBatch();
  14. conn.commit();
  15. pst.clearBatch();
  16. }
  17. }
  18. Long endTime = System.currentTimeMillis();
  19. System.out.println("pst+batch:"+(endTime-beginTime)/1000+"秒");
  20. pst.close();
  21. conn.close();
  22. } catch (SQLException e) {
  23. e.printStackTrace();
  24. }
  25. }

在Oracle 10g中测试,结果: 
1.使用statement  耗时142秒; 
2.使用PreparedStatement 耗时56秒; 
3.使用PreparedStatement + 批处理耗时: 
   a.50条插入一次,耗时5秒; 
    b.100条插入一次,耗时2秒; 
    c.1000条以上插入一次,耗时1秒; 
通过以上可以得出结论,在使用jdbc大批量插入数据时,明显使用第三种方式(PreparedStatement + 批处理)性能更优。

-------------------------------------------------------------------------------------------------------------------------------

  1. 普通方式处理大量数据的insert时,处理速度相当慢。
  2. */
  3. PreparedStatement ps = null;
  4. //循环10000次
  5. for(int i = 0; i < 100000; i++) {
  6. ps = con.prepareStatement(sql);
  7. ps.executeUpdate();
  8. }
    1. 方法二:通过addBatch()的方式,将数据缓存在对象里面,通过最后执行executeBatch();方法提交,因此速度会快很多!
    2. */
    3. PreparedStatement ps = con.prepareStatement(sql);
    4. for(int i = 0; i < 100000; i++) {
    5. ps.setString(1, "1");
    6. ps.setString(2, "2");
    7. ps.addBatch();
    8. }
    9. ps.executeBatch();

用Java向数据库中插入大量数据时的优化的更多相关文章

  1. MySQL_(Java)使用JDBC向数据库中插入(insert)数据

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC向数据库中插入(insert)数据 传送门 MySQL_(Java)使用JDBC向数据库中删除(d ...

  2. 通过mybatis向数据库中插入日期数据

    遇到的问题: 通过mybatis向数据库中插入日期格式数据,发现只有年月日, 没有小时分钟和秒 当你想在实体类中使用java.util.Date类型,而且还想在数据库中保存时分秒时, 解决办法: 你可 ...

  3. mysql/mariadb数据库在插入表数据时,ID竟然成奇数增加了?看完下面内容就知道怎么处理了。

    今天突然被问到一个问题,mysql数据库插入表数据时,设置了ID自增,但是插入数据后,ID却呈奇数增加,不是123456类型,而是13579形式,突然有点懵,研究了一会,发现是auto_increme ...

  4. 003杰信-在jsp页面输入数据,然后在oracle数据库中插入factory数据,当字段允许为空时要特殊处理

    本博客的内容全部来自于传智播客,特在此说明. 业务要求如下:在jsp页面(jFactoryCreate.jsp)上输入数据时,转到后台,并输入到数据库. jFactoryCreate.jsp页面:

  5. Java快速向数据库中插入大量数据 比如10万条以上

    String sql = "insert into table *****"; //必须要有这句,要不然效果不明显 con.setAutoCommit(false); ps = c ...

  6. SQL 数据库连续插入大批量数据时超时

    经常会处理大批量千万级的数据,一直以来都没问题.最近在处理时确出来了经常超时,程序跑一段时间就得停下来重启服务器,根据几次的调整发现了问题的所在,产生这类问题主要是以下几点所导致:      1.数据 ...

  7. Java程序向MySql数据库中插入的中文数据变成了问号

    找到mysql的安装目录,修改my.ini文件 (1)如何找到my.ini文件 如果my.ini文件不在MySQL的安装目录下,可能放在隐藏目录,要先去找到ProgramData,(这里要先打开显示隐 ...

  8. MySQL_(Java)使用JDBC向数据库中修改(update)数据

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC向数据库中插入(insert)数据 传送门 MySQL_(Java)使用JDBC向数据库中删除(d ...

  9. MySQL_(Java)使用JDBC向数据库中删除(delete)数据

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC向数据库中插入(insert)数据 传送门 MySQL_(Java)使用JDBC向数据库中删除(d ...

随机推荐

  1. 在Quartus中如何使用TCL脚本文件配制管脚

    quartus软件分配管脚的方法有两种,一是选择菜单“assignments->pins”进入管脚分配视图手动分配:第二种方法是利用tcl脚本文件自动分配.这里我来介绍第二种方法. 1.生成tc ...

  2. TCP/UDP,SOCKET,HTTP,FTP 简析

    (一)TCP/UDP,SOCKET,HTTP,FTP简析 TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层: 网络层:IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议 传 ...

  3. 修改host简化远程访问

    问题描述: 使用本机登陆服务器时,需要经常输入IP地址,在局域网下和非局域网下输入的IP又不一样,十分麻烦,如果可以给IP命名一个简单的名字,岂不是很方便? 解决方法: 修改host文件: vim / ...

  4. Cookie/Session编码

    Unicode编码:保存中文 中文与英文字符不同,中文属于Unicode字符,在内存中占4个字符,而英文属于ASCII字符,内存中只占2个字节.Cookie中使用Unicode字符时需要对Unicod ...

  5. 上传图片流到服务器(AFN方法) (多张图片)(图片流)

      上传图片流到服务器(AFN方法) (多张图片)(图片流) 第一步//获取图片 UIAlertController *actionSheet = [UIAlertController alertCo ...

  6. python爬虫请求库之selenium模块

    一 介绍     selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质是通过驱动浏览器,完全模拟浏览器 ...

  7. Ubuntu 给应用程序添加桌面图标(本文以Eclipse为例)

    这里以Eclipse为例: eclipse是下载的是解压就能用的,但是没有桌面图标就显得很无力了. 自己写了一个eclipse.desktop放到/usr/share/applications/目录下 ...

  8. 基于jQuery左侧小图滚动右侧大图显示代码

    今天给大家分享一款 jQuery左侧小图滚动右侧大图显示代码是一款基于jQuery实现的左侧滚动图片点击大图查看效果代码.该实例适用浏览器:IE8.360.FireFox.Chrome.Safari. ...

  9. 改进cocos2dx中lua读ccb的方法

    cocos2dx自带的CCBProxy真弱,还好提供了一个CCBReaderLoader.lua,但是也不好用, 于是修改了一下CCBReaderLoader,下面直接贴代码了. function N ...

  10. 【基础练习】【区间DP】codevs2102 石子归并2(环形)题解

    题目描写叙述 Description 在一个园形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次仅仅能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个 ...