zoukankan      html  css  js  c++  java
  • mysql数据库批量高速插入

    近期在处理一批数据,须要从库中表里的字段进行处理然后导出到一个新表中。只是这个表的数据量有近500w条。

    这数据量出现的的问题是须要处理的时间好长。
    首先想到,一句一句的插入,大数据量处理时间好长,忽略。


    其次想到,多线程插入,想到数据库连接是须要同步的所以感觉用处不大。
    最后想到,使用 PreparedStatement 预编译sql 进行批量插入 batch 处理。


    好吧。如今就进行批处理插入測试。
    1、使用简单的 batch

    public static void main(String[] args) {
            Connection conn = getConn(lsqlurl, luser, lpassword);
            long startTime = System.currentTimeMillis();
            try {
                PreparedStatement pst = conn.prepareStatement("insert into testmy (id,name,age) values (?

    ,?,?

    )"); for (int i = 0; i < 2000; i++) { pst.setInt(1, 3); pst.setString(2, "xx"); pst.setInt(3, 10); pst.addBatch(); } pst.executeBatch(); long endTime = System.currentTimeMillis(); System.out.println((endTime - startTime)/1000+"s"); System.out.println("test sql batch--->2000....."); } catch (SQLException e) { e.printStackTrace(); }finally { if(conn!=null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } }

    你会发现时间会是30s 左右。


    2k行的数据插入就30秒 。
    2w行数据插入时间为940秒(约16min)。

    2、改动自己主动提交的 batch

    public static void main(String[] args) {
            Connection conn = getConn(lsqlurl, luser, lpassword);
            long startTime = System.nanoTime();
            try {
                conn.setAutoCommit(false);
                PreparedStatement pst = conn.prepareStatement("insert into test (id,name,age) values (?,?,?

    )"); for (int i = 0; i < 2000; i++) { pst.setInt(1, 3); pst.setString(2, "xx"); pst.setInt(3, 10); pst.addBatch(); } pst.executeBatch(); conn.commit(); long endTime = System.nanoTime(); System.out.println((endTime - startTime)/1000000+"ms"); System.out.println("test sql batch--->2000....."); } catch (SQLException e) { try { conn.rollback();

  • 相关阅读:
    20200924-2 功能测试
    作业要求20200924-4 代码规范,结对要求
    20200924-1 每周例行报告
    20200929-git地址
    白名单
    作业要求 20200917-1 每周例行报告
    词频统计 SPEC
    20200910-1 每周例行报告
    20200924-3 单元测试,结对
    20200924-5 四则运算试题生成,结对
  • 原文地址:https://www.cnblogs.com/tlnshuju/p/7081954.html
Copyright © 2011-2022 走看看