[java]读取.csv文件数据,并插入数据库

这里使用BufferedReader将csv中数据读取到list中:

/**
     * 把数据从csv中读取到list
     * @return
     */ public static List<KGInfo> readCSV(String fileName) {
        List<KGInfo>kgInfoList=new ArrayList<>();
        try {
            BufferedReader reader = new BufferedReader(new FileReader("E:\\ftpdata\\"+fileName));// 文件名
            reader.readLine();//第一行信息,为标题信息,不用,如果需要,注释掉
            String line = null;
            while ((line = reader.readLine()) != null) {
                KGInfo kgInfo=new KGInfo();
                String item[] = line.split(",");// CSV格式文件为逗号分隔符文件,这里根据逗号切分
                kgInfo.setMerchantOrderID(item[0]);
                kgInfo.setAuthCode(item[1]);
                kgInfo.setAmountRequested(item[2]);

                kgInfoList.add(kgInfo);
            }
//                System.out.println("从CSV中读取到的数据:" + kgInfoList);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return kgInfoList;
    }

将list数据存储到mysql数据库:

/**
     * 批量插入到数据库
     * @param list
     */ public static void insertTel_test(List<KGInfo> list) throws SQLException {
        Connection conn = null;
        // 驱动程序名
        String driver = "com.mysql.jdbc.Driver";
        // URL指向要访问的数据库名mydata
        String url = "jdbc:mysql://***:3306/test?characterEncoding=utf8&allowMultiQueries=true&connectTimeout=5000&autoReconnect=true&zeroDateTimeBehavior=convertToNull";
        // MySQL配置时的用户名
        String user = "test";
        // MySQL配置时的密码
        String password = "*****";
        // 遍历查询结果集
        // 加载驱动程序
        try {
            Class.forName(driver);
            // 连接MySQL数据库!!
            conn = DriverManager.getConnection(url, user, password);
            conn.setAutoCommit(false);
            PreparedStatement prep = conn.prepareStatement("INSERT INTO `test`.`kadata1`  VALUES (?,?,?)"); //需要替换
            int num=0;
            for (KGInfo value : list) {
                num++;
                prep.setString(1, value.getMerchantOrderID());
                prep.setString(2,value.getAuthCode());
                prep.setString(3,value.getAmountRequested());
                prep.addBatch();
                if(num>50000){
                    System.out.println(prep);
                    prep.executeBatch();
                    conn.commit();
                    num=0;
                }
                System.out.println(prep);
                prep.executeBatch();
                conn.commit();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

 

  • 4
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是Java读取CSV文件并将其导入到达梦数据库的示例代码: ```java import java.io.BufferedReader;import java.io.FileReader; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; public class CsvToDatabase { public static void main(String[] args) { String csvFile = "path/to/csv/file.csv"; String jdbcUrl = "jdbc:dm://localhost:5236"; String username = "username"; String password = "password"; String tableName = "table_name"; try { // 创建数据库连接 Connection conn = DriverManager.getConnection(jdbcUrl, username, password); // 准备SQL语句 String sql = "INSERT INTO " + tableName + " VALUES (?, ?, ?)"; PreparedStatement statement = conn.prepareStatement(sql); // 读取CSV文件 BufferedReader reader = new BufferedReader(new FileReader(csvFile)); String line; while ((line = reader.readLine()) != null) { // 解析CSV行 String[] fields = line.split(","); // 设置SQL参数 statement.setString(1, fields[0]); statement.setString(2, fields[1]); statement.setString(3, fields[2]); // 执行SQL语句 statement.executeUpdate(); } // 关闭资源 reader.close(); statement.close(); conn.close(); System.out.println("CSV文件已成功导入到数据库中。"); } catch (Exception e) { e.printStackTrace(); } } } ``` 请注意,您需要将示例代码中的以下变量替换为您自己的值: - csvFile:CSV文件的路径。 - jdbcUrl:达梦数据库的JDBC URL。 - username:数据库用户名。 - password:数据库密码。 - tableName:要将数据插入的表的名称。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值