雅痞Joy 2013-04-23 18:35
浏览 427
已采纳

Java处理30W数据入库的问题!

30W的数据保存在txt文件中,格式如下:

部门名称,部门id,上级部门id,等级

部门名称1,001,01,2 //01表示企业id
部门名称2,002,001,2
部门名称3,003,002,2

其中每条记录要插入的表有部门表,部门关系表,名片表。

问题:该如何处理这些数据保存到mysql数据库,获得较高的性能??

  • 写回答

6条回答 默认 最新

  • joelle(喬如) 2013-04-23 22:49
    关注

    楼主不妨看下我的代码,处理1000万10几分钟就OK了:

    [code="java"]
    package net.ltan.test;

    import java.io.BufferedReader;
    import java.io.BufferedWriter;
    import java.io.File;
    import java.io.FileReader;
    import java.io.FileWriter;
    import java.sql.Connection;
    import java.sql.DriverManager;

    public class SQLTools {

        private static int failed = 0;
        private static int success = 0;
        private static final String MYSQLDRIVER = "com.mysql.jdbc.Driver";
        private static final String MYSQLURL = "jdbc:mysql://localhost:3306/db?user=root&password=&useUnicode=true&characterEncoding=utf8&autoReconnect=true";//使用时修改下数据库连接信息
    
        /**
         * 数据库更新
         * @param sql
         */
        public static void executeSQL(StringBuilder sql) {
                try {
                        Class.forName(MYSQLDRIVER);
                        Connection conns = DriverManager.getConnection(MYSQLURL);
                        conns.prepareStatement(sql.toString()).execute();
                } catch (Exception e) {
                        e.printStackTrace();
                }
        }
    
        /**
         * 把SQL批量插入数据库
         */
        public static void getSql(){
                try {
                        File file=new File("d:/csdn/");
                          String test[];
                          test=file.list();
                          for(int i=0;i<test.length;i++){
                                  BufferedReader br = new BufferedReader(new FileReader(new File("d:/csdn/"+test[i])));
                                  StringBuilder sb = new StringBuilder();
                                  String temp = null;
                                  while((temp=br.readLine())!=null){
                                          sb.append(temp);
                                  }
                                  System.out.println("开始导入:"+test[i]);
                                  executeSQL(sb.delete(sb.length()-1, sb.length()));
                          }
                } catch (Exception e) {
                        e.printStackTrace();
                }
        }
    
        /**
         * 把txt转换成批量SQL
         */
        public static void toSql(){
                try {
                        StringBuilder sb = new StringBuilder();
                        BufferedReader br = new BufferedReader(new FileReader(new File("d:/www.csdn.net.sql")));//数据库地址
                        BufferedWriter bw = null;
                        String temp = null;
                        while((temp = br.readLine())!=null){
                                if (success%10000==0) {
                                        sb.append("INSERT INTO CSDN (username,password,email) VALUES ");
                                        bw = new BufferedWriter(new FileWriter(new File("d:/csdn/csdn_sql_"+(success/10000)+".txt")));//转换后存放数据库的目录
                                }
                                String str[] = temp.split("\\s#\\s");
                                if (str.length == 3) {
                                        sb.append("(");
                                        for (int i = 0; i < str.length; i++) {
                                                sb.append((i!=3-1?"'"+sqlSpecialChars(str[i])+"',":"'"+sqlSpecialChars(str[i])+"'"));//Mysql特殊字符转意
                                        }
                                        sb.append("),");
                                        bw.write(sb.toString());
                                        bw.newLine();
                                        bw.flush();
                                        sb.setLength(0);
                                        ++success;
                                        System.out.println("转换成功:"+success+"次。");
                                }else {
                                        ++failed;
                                        System.out.println("转换失败:"+failed+"次。");
                                }
                        }
                        System.out.println("转换完成,共转换:"+success+"次。失败:"+failed+"次。");
                        System.out.println("-----------------开始导入SQL到数据库--------------");
                        getSql();
                } catch (Exception e) {
                        e.printStackTrace();
                }
        }
    
        /**
         * 转意MYSQL中的特殊字符
         * @param str
         * @return
         */
        public static String sqlSpecialChars(String str) {
        str = str.replaceAll("\"", "\\\\\"");
        str = str.replaceAll("\\\\", "\\\\\\\\");
        str = str.replaceAll("'", "\\\\'");
        return str;
        }
    
        public static void main(String[] args) {
                toSql();
        }
    

    }
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog