CSV文件转换SQL文件

有段时间没用csdn了,今天随手写个csv文件转sql文件的方法,以便以后有机会用到。

其实csv转sql有多种方式,比如直接利用mysql客户端工具去转、通过代码方法转等

这里先记录下用java代码方式去转换下,转换方法如下:

package com.swhysc.ubsp.service.business.service.impl.paperless;
import lombok.SneakyThrows;

import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
/**
 * @ClassName CsvToSqlConverter
 * @Description csv转sql
 * @Author xqy
 * @Date 2023/8/21 14:39
 * @Version 1.0
 */
public class CsvToSqlConverter {

    public static void main(String[] args) {
        String csvFilePath = "C:\\Users\\MI\\Desktop\\密码重置\\20230816-layout_lht1.csv"; // 输入CSV文件路径
        String sqlFilePath = "C:\\Users\\MI\\Desktop\\密码重置\\20230816-layout_lht1.sql"; // 输出SQL文件路径

        List<String> sqlStatements = convertCsvToSql(csvFilePath);

        if (writeSqlFile(sqlFilePath, sqlStatements)) {
            System.out.println("SQL file generated successfully!");
        } else {
            System.out.println("Failed to generate SQL file.");
        }
    }

    @SneakyThrows
    public static List<String> convertCsvToSql(String csvFilePath) {
        List<String> sqlStatements = new ArrayList<>();

        //BufferedReader reader = new BufferedReader(new FileReader(csvFilePath));
        InputStreamReader isr = new InputStreamReader(new FileInputStream(csvFilePath), "GB2312");
        try (BufferedReader reader=new BufferedReader(isr)) {
            String line;
            while ((line = reader.readLine()) != null) {
                String[] values = line.split(",");
                String tableName = "ubsp_layout.business_process"; // 设置要插入的目标表名

                StringBuilder sqlStatement = new StringBuilder();
                sqlStatement.append("INSERT INTO ").append(tableName).append(" VALUES (");

                for (String value : values) {
                    value = value.replace("\"","");
                    sqlStatement.append("'").append(value).append("',");
                }

                sqlStatement.deleteCharAt(sqlStatement.length() - 1); // 删除最后一个逗号
                sqlStatement.append(");");

                sqlStatements.add(sqlStatement.toString());
            }
        } catch (IOException e) {
            e.printStackTrace();
        }

        return sqlStatements;
    }

    @SneakyThrows
    public static boolean writeSqlFile(String sqlFilePath, List<String> sqlStatements) {
        //FileWriter writer = new FileWriter(sqlFilePath);;
        try (BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(sqlFilePath), "UTF-8"))) {
            for (String statement : sqlStatements) {
                writer.write(statement);
                writer.write("\n");
            }

            return true;
        } catch (IOException e) {
            e.printStackTrace();
            return false;
        }
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CSV文件是一种常见的数据存储格式,而SQL文件是一种用于数据库操作的脚本文件。将CSV文件SQL文件的过程,主要是将CSV文件中的数据转换SQL语句的插入语句,以便能够将数据导入到数据库中。 首先,我们需要创建一个适合存储CSV文件数据的数据表。根据CSV文件的结构,定义SQL表的各列以及数据类型。 然后,可以使用编程语言,如Python或Java,来读取CSV文件。将CSV文件逐行解析,获取每行数据的值,并根据表的结构,构建SQL插入语句。 在构建插入语句时,需要将CSV文件中的每一列的值按照相应的数据类型进行处理。例如,对于日期类型的列,需要将CSV文件中的日期字符串转换为数据库支持的日期格式。 在构建完插入语句后,将其写入到一个SQL文件中。可以使用文件操作函数将SQL插入语句写入文件中,每条插入语句占一行。 最后,将生成的SQL文件导入到数据库中。可以使用数据库命令行工具,如MySQL的mysql命令,运行该SQL文件,执行插入语句将数据导入到对应的数据表中。 需要注意的是,转换过程中还要处理一些特殊情况,如空值、特殊字符等。同时,如果CSV文件较大,可能需要考虑分批导入数据,避免数据量过大导致数据库性能下降。 综上所述,将CSV文件转换SQL文件的过程,主要包括创建表结构、解析CSV文件、构建SQL插入语句和导入数据库等步骤。这样可以方便地将CSV文件中的数据导入到数据库中,以便进行后续的数据操作和分析。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

纯洁的一笑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值