java - 如何从 Excel 读取 SQL 查询并传递到 JDBC 代码

标签 java apache-poi

有人可以对以下查询提出建议/提供帮助吗?

我有下面的代码,它从数据库中检索数据,我正在对 SQL 查询进行硬编码,希望传入 Excel 并从 Excel 中读取 SQL 查询,并将 SQL 查询输出存储在结果列中。

package com.DBUtility;

import java.io.*;  
import java.sql.*;  


public class DataRetrieveMainClass {  
    public static void main(String args[]) throws Exception {

    PrintColumnAndData PrintCl=new PrintColumnAndData();

        try {
            Class.forName("oracle.jdbc.driver.OracleDriver");
            Connection con = DriverManager.getConnection("jdbc:oracle:thin:@123.32.23.123:8080/orcl", "Test1", "******");

            PreparedStatement ps = con.prepareStatement("select * from MSG where MID='1234'");
            ResultSet rs = ps.executeQuery();

            try {

                PrintCl.printResultColumns(rs);
            } catch (SQLException e) {
                System.err.println(e.getMessage());
            }

            con.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}


** - Excel File:**

SQL QUERY                                    RESULT
______________________________________________________
select * from MSG where MID='1234'

Excel

最佳答案

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

private static ArrayList<MyObject> getSQLObjects(){
    PrintColumnAndData PrintCl=new PrintColumnAndData();
    ArrayList<MyObject> objList = new ArrayList<MyObject>();
    try {
        Class.forName("oracle.jdbc.driver.OracleDriver");
        try (Connection con = DriverManager.getConnection("jdbc:oracle:thin:@123.32.23.123:8080/orcl", "Test1", "******")){
            PreparedStatement ps = con.prepareStatement("select * from MSG where MID='1234'");
            ResultSet rs = ps.executeQuery();
            while(rs.next()) {
                MyObject object = new MyObject();
                //set object values for each column using rs.getString() etc.
            objList.add(object);
            }
        }
    }catch(SQLException e) {
        e.printStackTrace();
    }catch(ClassNotFoundException e) {
        e.printStackTrace();
    }catch (Exception e) {
        e.printStackTrace();
    }
    return objList;
}

private static void writeExcel(ArrayList<MyObject> objList) {
    Workbook book = null;
    try {
        try {
            book = new WorkbookFactory.create(new File("myFile"));
            Sheet sheet = book.getSheet("mySheet");
            int startRow = 1;
            for(MyObject obj : objList) {
                Row row = sheet.createRow(startRow);
                row.getCell(0).setCellValue(obj.value);
                row.getCell(1).setCellValue(obj.otherValue);
                //etc.
                startRow++;
            }
            book.write(new FileOutputStream(new File("myFile")));
        }finally {
            book.close();
        }
    }catch(IOException e) {
        e.printStackTrace();
    }catch(Exception e) {
        e.printStackTrace();
    }
}

这对您来说应该是一个巨大的帮助(可能需要稍微修改以满足您的需求,但仍然应该为您提供解决方案的“ map ”)。您的代码目前看起来有点笨拙并且非常困惑。您应该将 SQL 数据库调用和 Excel 写入分离到单独的方法(如果不是类)中来处理这些;我个人甚至为连接本身创建了一个类。您还应该考虑创建一个类来表示在两者之间传递的对象(数据传输对象)。

我假设的一些事情:您正在使用 Apache POI for excel,您的 excel 文件和工作表已经存在(您只是填充它),并且工作表的第一行中有标题(因此 startRow = 1).

关于java - 如何从 Excel 读取 SQL 查询并传递到 JDBC 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57362508/

相关文章:

java - JFrame "blocking"显示()

java - 使用 Jetty 运行多模块 Maven Web 应用程序,HTTP 错误 : 503 SERVICE_UNAVAILABLE

java - jOOQ 提示排除表的多重继承

java - 使用 Bi 谓词对数组进行排序

java - 如何缓存 InputStream 以供多次使用

Java 自定义通用列表 : add() method error

java - 使用 POI 从 URL 读取 Excel 文件

java - 提高 jXLS 的性能

使用 Apache.POI 读写 Excel 的 Java 内存问题

java - 如何使用java检查xlsx中的行是否为空