我是靠谱客的博主 顺利夕阳,最近开发中收集的这篇文章主要介绍jdbc批处理+事务处理 十万级数据导入,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

这个比较简单,从一个远程数据库导出一张10万数据级的表到本地数据库,下面展示代码,一个3个类,2个数据库连接,一个实现

/**
 * 远程取数据的数据库
 * @author Administrator
 *
 */
public class DbJob {
    private String url = "jdbc:oracle:thin:@127.0.0.1:1521:ORCL";//远程数据库地址,这个我给换本地了,以防暴露了,哈哈
    private String username = "system";
    private String pw = "12345";
    public Connection getConnection() {
     try {
      Class.forName("oracle.jdbc.driver.OracleDriver");
      try {
       conn = DriverManager.getConnection(url, username, pw);
      } catch (SQLException e) {
       e.printStackTrace();
      }
     } catch (ClassNotFoundException e) {
      e.printStackTrace();
     }
     return conn;
   }
}
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
/**
 * 目标数据库(需要插入的数据库)
 * @author Administrator
 *
 */
public class DbTarget {
    private String url = "jdbc:jtds:sqlserver://127.0.0.1:1433/bigdata";//这个地址也改了,也可以是远程数据库,注意,目标数据库的表需要先建立起来,因为两个数据库一个orcal,一个sqlserver,数据结构不同所以需要手动修改再建立表。sql我就不写了。
    private String username = "admin";
    private String pw = "54321";
    private Connection conn = null;
    public Connection getConnection() {
     try {
      Class.forName("net.sourceforge.jtds.jdbc.Driver");
      try {
       conn = DriverManager.getConnection(url, username, pw);
      } catch (SQLException e) {
       e.printStackTrace();
      }
     } catch (ClassNotFoundException e) {
      e.printStackTrace();
     }
     return conn;
   }
}
/**
 * 数据导入
 * @author Administrator
 *
 */
public class ConvertDataFromData {
    DbJob dbJob;
    DbTarget dbTarget;

    public ConvertDataFromData() {
        dbTarget = new DbTarget();
        dbJob = new DbJob();
    }
    //导入数据
    public void go() {
        try  {
            Connection targetConn = dbTarget.getConnection();
            Connection jobConn = dbJob.getConnection();
            // 从job库移到target库
            //先把事务自动提交关闭
            targetConn.setAutoCommit(false);
            PreparedStatement jps = jobConn.prepareStatement("select * from region");
            ResultSet rs = jps.executeQuery();
            if (!rs.next()) return;
            PreparedStatement cps = targetConn.prepareStatement("insert into region(REGION_ID,REGION_FIRST_CODE) values (?,?)");
            int index = 0;
            long start = System.currentTimeMillis();
            do {
                cps.setInt(1, rs.getInt(1));
                cps.setString(2, doSome(rs.getString(2)));// 需要做处理的数据               
                cps.addBatch();
                if (index++ % 500 == 0) {
                //500条数据批处理
                    cps.executeBatch();
                }
            } while (rs.next());
            if (index % 500 != 0) {
                cps.executeBatch();
            }
            //提交事务
            targetConn.commit();
            rs.close();
            //简写了 关闭连接
            jobConn.close();
            targetConn.close();
            System.out.println("total of data is " + index + ", used " + ((System.currentTimeMillis() - start)/1000) +"  s");
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public String doSome(String str) {
        // TODO 逻辑处理
        return str;
    }

    public static void main(String[] args) {
        new ConvertDataFromData().go();
    }
}

最后

以上就是顺利夕阳为你收集整理的jdbc批处理+事务处理 十万级数据导入的全部内容,希望文章能够帮你解决jdbc批处理+事务处理 十万级数据导入所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部