java实现数据库之间批量插入数据

java实现数据库之间批量插入数据

 
package comnf147Package;

import java.sql.*;

public class DateMigrationLagou {
    
    //连接SQLite
    private Connection getSqlite() throws Exception {
        Class.forName("org.sqlite.JDBC");
        return DriverManager.getConnection("jdbc:sqlite:E:\\data\\lagou.db");
    }

    //连接MariaDB
    private Connection getMariaDb() throws Exception {
        Class.forName("com.mysql.jdbc.Driver");
        return DriverManager.getConnection("jdbc:mysql://localhost:3306/lagouDB?rewriteBatchedStatements=true", "root", "666666");
    }

    //释放资源
    private void release(Connection coon, Statement st, ResultSet rs) {
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (st != null) {
            try {
                st.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (coon != null) {
            try {
                coon.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    public void OperatingControl() {

        //从SQLite中取数据
        Connection SQliteConn = null;
        Statement SQliteSt = null;
        ResultSet SQliteRS = null;

        //添加到MaiiaDb
        Connection MariaDbConn = null;
        PreparedStatement MariaDbPs = null;


        try {
            //获取数据
            SQliteConn = this.getSqlite();
            SQliteSt = SQliteConn.createStatement();
            SQliteRS = SQliteSt.executeQuery("select * from lagou_position");

            //添加数据
            MariaDbConn = this.getMariaDb();
            MariaDbPs = MariaDbConn.prepareStatement("insert into lagou_position values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)");

            // 关闭事务自动提交 ,这一行必须加上,否则每插入一条数据会向log插入一条日志
            MariaDbConn.setAutoCommit(false);

            int i = 0;
            //计时开始
            long startime = System.currentTimeMillis();
            //设置批量处理的数量

            while (SQliteRS.next()) {
                for (int j = 1; j < 20; j++) {
                    MariaDbPs.setObject(j, SQliteRS.getObject(j));
                }
                MariaDbPs.addBatch();
                //把若干sql语句装载到一起,然后一次送到数据库执行,执行需要很短的时间
                // 每 10000 条,向数据库发送一次执行请求
                if (++i % 10000 == 0) {
                    MariaDbPs.executeBatch();
                }
            }
            //执行批量处理语句;
            MariaDbPs.executeBatch();
             提交事务
            MariaDbConn.commit();

            //结束时间
            long stoptime = System.currentTimeMillis();
            //输出结果
            System.out.println("总数据" + i);
            System.out.println("插入用时" + (stoptime - startime) / 1000.0 + " 秒 ");
        } catch (Exception e) {
            try {
                if (MariaDbConn != null) {
                    MariaDbConn.rollback();
                }
            } catch (SQLException e1) {
            }
        } finally {
            this.release(SQliteConn, SQliteSt, SQliteRS);
            this.release(MariaDbConn, MariaDbPs, null);
        }
    }

}
    public static void main(String[] args) {

        //调用方式
        DateMigrationLagou dateMigrationLagou = new  DateMigrationLagou();
        dateMigrationLagou.OperatingControl();
    }
    

 

 
 
 
 
 
 
 
posted @ 2018-11-22 08:49 梓鸿 阅读(...) 评论(...) 编辑 收藏
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值