Java—查询Oracle数据库输出CSV文件(一)

这里我使用的是JDBC + org.apache.commons.csv组件

一、引入pom.xml依赖

<dependencies>
   <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>2.2.0</version>
    </dependency>
    <dependency><!-- 添加oracle依赖 -->
        <groupId>com.oracle.database.jdbc</groupId>
        <artifactId>ojdbc8</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency><!-- 添加Csv依赖 -->
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-csv</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

二、DBUtils工具类

package com.example.demo;

import java.sql.*;

public class DBUtils {
    private static final String DRIVER = "oracle.jdbc.driver.OracleDriver";
    private static final String URL = "jdbc:oracle:thin:@localhost:1521:database";
    private static final String USER = "***";
    private static final String PASSWORD = "***";
    private static PreparedStatement sta = null;
    private static ResultSet rs = null;
    private static Connection conn = null;

    /**
     * 加载驱动程序
     */
    static {
        try {
            Class.forName(DRIVER);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    /**
     * @return 连接对象
     */
    public static Connection getConn() {
        try {
            conn = DriverManager.getConnection(URL, USER, PASSWORD);
        } catch (SQLException e) {

            e.printStackTrace();
        }
        return conn;
    }

    /**
     * @param sql sql语句  增加,删除,修改
     * @param obj 参数
     * @return
     */
    public static int update(String sql, Object... obj) {
        int count = 0;
        conn = getConn();
        try {
            sta = conn.prepareStatement(sql);
            if (obj != null) {
                for (int i = 0; i < obj.length; i++) {
                    sta.setObject(i + 1, obj[i]);
                }
            }
            count = sta.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally{
            close();
        }
        return count;
    }

    /**
     * @param sql sql语句
     * @param obj 参数
     * @return 数据集合
     */
    public static ResultSet Query(String sql,Object...obj){
        conn=getConn();
        try {
            sta=conn.prepareStatement(sql);
            if(obj!=null){
                for(int i=0;i<obj.length;i++){
                    sta.setObject(i+1, obj[i]);
                }
            }
            rs=sta.executeQuery();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return rs;
    }

    /**
     * 关闭资源
     */
    public static void close() {
        try {
            if (rs != null) {
                rs.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (sta != null) {
                    sta.close();
                }
            } catch (SQLException e2) {
                e2.printStackTrace();
            } finally {
                if (conn != null) {
                    try {
                        conn.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
    }
}

三、创建Csv写入方法

/**
  * 写入csv文件
  * 列头 Object[] headers,
  * @param data 数据内容
  **/
 public static void writeCsv(Object[] headers,List<String[]> data) throws IOException {
     CSVFormat formator = CSVFormat.DEFAULT.withRecordSeparator("\n");
     File file = new File("D:/csv/test.csv"); // 输出路径以及文件名称
     System.out.println("---------开始传输文件---------");
     // 输出流,并设置字符编码
     OutputStreamWriter outputStreamWriter=new OutputStreamWriter(new FileOutputStream(file),"GBK"); 
     BufferedWriter bw = new BufferedWriter(outputStreamWriter);
     // 将输出流 和 CSV文件分隔符 放入CSVPrinter对象
     CSVPrinter printer = new CSVPrinter(bw, formator);
     printer.printRecord(headers); // 写入头信息
     if (null != data) {
         for (String[] lineData : data) { // 循环写入数据
             printer.printRecord(lineData);
         }
     }
     // 刷新
     bw.flush();
     // 关闭资源
     printer.close();
     bw.close();
     System.out.println("---------结束传输文件---------");
 }

四、创建查询数据方法,并调用Csv写入方法

/**
 * 查询数据库数据,并调用CSV文件写入方法
 */
public static void selectBom() throws Exception {
     List<String[]> list = new ArrayList<>();
     String sql = "SELECT t1.FNUMBER code,t1.FNAME_L2 name FROM T_MM_Bom t1";
     ResultSet rs = DBUtils.Query(sql, null);
     String[] bom = null;
     while (rs.next()) {
         bom = new String[]{rs.getString("code"),rs.getString("name")};
         list.add(bom);
     }
     DBUtils.close();
     String[] str = {"编码","名称"}; // Csv文件头信息
     writeCsv(str,list);  // 调用Csv写入方法
 }

五、调用 并 输出结果

public static void main(String[] args) throws Exception {
  	selectBom();
}

在这里插入图片描述

1、输出的文件默认是EXCEL表格方式打开,也可以用文本方式打开
2、org.apache.commons.csv组件输出的CSV文件用文本方式打开的时候,输出的数据不带双引号
在这里插入图片描述

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用java语言查询表数据并导出csv文件可以使用Java语言中提供的JDBC API和ResultSet类。首先,连接数据库,然后构建查询语句,接着使用ResultSet类检索查询结果,最后将结果写入CSV文件中。 ### 回答2: 使用Java语言查询表数据并导出成CSV文件可以分为以下几个步骤: 1. 连接数据库:首先,需要在Java代码中连接到数据库。可以使用Java提供的JDBC(Java Database Connectivity) API来连接到各种类型的数据库,如MySQL、Oracle等。需要设置连接URL、用户名和密码等数据库连接信息。 2. 执行查询语句:通过使用Java的JDBC API,可以执行SQL查询语句从表中获取数据。可以使用预编译的语句来参数化查询语句,以便更安全和高效地执行查询操作。 3. 将查询结果写入CSV文件:在获取查询结果后,通过Java中的文件操作API,可以将查询结果写入CSV文件。可以使用Java中的File类和相关的输入/输出流来创建、写入和关闭CSV文件。 4. CSV文件格式:CSV文件是以逗号分隔的文本文件,每行代表表中的一条数据记录,每个字段之间使用逗号分隔。可以使用Java中的字符串操作API来格式化数据并写入CSV文件中。 5. 异常处理:在代码中需要进行适当的异常处理,例如数据库连接失败、SQL语句执行错误或文件操作错误等。可以使用Java中的异常处理机制(try-catch-finally)来捕获和处理异常,并在出现异常时进行适当的处理,如记录日志或回滚事务。 总结起来,使用Java语言查询表数据并导出成CSV文件,主要涉及到数据库连接、SQL查询文件操作和异常处理等方面的知识。通过合理应用Java中的API和相关技术,可以实现对表数据的查询和导出操作,生成符合CSV格式的文件。 ### 回答3: 在使用Java语言查询表数据并导出为CSV文件之前,首先需要使用Java数据库连接(JDBC)驱动连接到数据库。可以选择合适的JDBC驱动程序来连接不同类型的数据库,比如MySQL、Oracle等。 然后,通过编写Java代码来执行SQL查询语句来获取表中的数据。可以使用PreparedStatement或Statement对象来执行查询,并通过ResultSet对象来获取查询结果的数据。 接下来,需要将查询结果的数据按照CSV文件的格式进行处理,即将每一行数据转换为以逗号分隔的字段。可以使用StringBuilder或StringBuffer来构建CSV文件的内容。 最后,将CSV文件内容写入到磁盘上的文件中。可以使用FileWriter或BufferedWriter等类来实现文件的写入操作。在写入过程中,需要注意处理异常和关闭文件资源。 以下是一种可能的实现方式: 1. 导入JDBC驱动: ```java import java.sql.*; ``` 2. 连接到数据库: ```java String url = "jdbc:mysql://localhost:3306/数据库名"; String User = "用户名"; String Password = "密码"; Connection conn = null; try { conn = DriverManager.getConnection(url, user, password); } catch (SQLException e) { e.printStackTrace(); } ``` 3. 执行SQL查询语句并获取结果: ```java String sql = "SELECT * FROM 表名"; Statement stmt = null; ResultSet rs = null; try { stmt = conn.createStatement(); rs = stmt.executeQuery(sql); // 处理查询结果,将数据转换为CSV格式 StringBuilder csvContent = new StringBuilder(); ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); // 写入CSV列名 for (int i = 1; i <= columnCount; i++) { csvContent.append(metaData.getColumnLabel(i)); if (i < columnCount) { csvContent.append(","); } } csvContent.append("\n"); // 写入CSV数据 while (rs.next()) { for (int i = 1; i <= columnCount; i++) { csvContent.append(rs.getString(i)); if (i < columnCount) { csvContent.append(","); } } csvContent.append("\n"); } // 将CSV内容写入文件 String csvFilePath = "导出文件路径"; BufferedWriter writer = null; try { writer = new BufferedWriter(new FileWriter(csvFilePath)); writer.write(csvContent.toString()); } catch (IOException e) { e.printStackTrace(); } finally { if (writer != null) { try { writer.close(); } catch (IOException e) { e.printStackTrace(); } } } } catch (SQLException e) { e.printStackTrace(); } finally { try { if (rs != null) { rs.close(); } if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } ``` 以上代码示例展示了如何使用Java语言查询表数据并将其导出为CSV文件。需要注意的是,代码中的数据库连接信息、SQL语句、导出文件路径等都需要根据实际情况进行修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值