java - jdbc apache poi 创建 xls 文件

标签 java postgresql jdbc apache-poi resultset

我编写了以下程序来从 postgres 数据库获取表列表并将它们写入 xls 文件。我已经包含了 Apache poi 库来编写 xls 文件。程序运行时没有任何错误,也创建了文件,但输出未写入文件,文件只是空的。请帮我将结果集写入文件中。

package list;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;

public class List 
{
 public static void main(String[] args) throws SQLException, FileNotFoundException,   IOException 
{

 Connection con = DriverManager.getConnection( "jdbc:postgresql://localhost:5432/db","user","pass");

  DatabaseMetaData md = con.getMetaData();
  ResultSet rs = md.getTables(null, "public", "%", null);

  try (FileOutputStream fileOut = new FileOutputStream("/home/usr/Desktop/list.xls")) 
  {

            Workbook wb = new HSSFWorkbook();
            Sheet sheet1 = wb.createSheet("Table List");
            Row row = sheet1.createRow(250);
            while (rs.next()) 
            {
    row.createCell(0).setCellValue(rs.getString(3));

            }
             wb.write(fileOut);  
             fileOut.close();

  }
  catch(SQLException e) 
   { 
       System.out.println( "could not get JDBC connection : " + e ); 
   } 

  }
  }

最佳答案

我已经重写了代码,如下所示,现在它可以工作了。

            int i = 0;
                while (rs.next()) 
            {

            Row row = sheet1.createRow(i);

            row.createCell(0).setCellValue(rs.getString(3));

            i++;
            }
             wb.write(fileOut);  

关于java - jdbc apache poi 创建 xls 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13736598/

相关文章:

java - 是否有一种实用方法可以通过给定的字符串分隔列表?

java - 计算java日期时间时的负值

python - Django 无法在 PostgreSQL 上创建 super 用户。 "server closed the connection unexpectedly"

java - 手动加载 native 库以规避限制性环境

java - 如何将进度监视器传递给多个子程序?

java - 正确修复 Java 10 提示 jaxb-impl 2.3.0 非法反射访问?

sql - 优化对大表的最近行的查询性能

sql - 从 Postgresql 中删除记录

java - 提交或 conn.setAutoCommit(true)

java - tomcat jdbc SlowQueryReport拦截器-单独文件登录