gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 02:04:37 26 4
gpt4 key购买 nike

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

我有下面的代码,它从数据库中检索数据,我正在对 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com