- Apache POI Tutorial
- Apache POI - Home
- Apache POI - Overview
- Apache POI - Java Excel APIs
- Apache POI - Environment
- Apache POI - Core Classes
- Apache POI - Workbooks
- Apache POI - Spreadsheets
- Apache POI - Cells
- Apache POI - Fonts
- Apache POI - Formula
- Apache POI - Hyperlink
- Apache POI - Print Area
- Apache POI - Database
- Apache POI Resources
- Apache POI - Questions & Answers
- Apache POI - Quick Guide
- Apache POI - Useful Resources
- Apache POI - Discussion
Apache POI - 数据库
本章介绍 POI 库如何与数据库交互。在 JDBC 的帮助下,您可以从数据库检索数据并使用 POI 库将该数据插入到电子表格中。让我们考虑用于 SQL 操作的 MySQL 数据库。
从数据库写入Excel
让我们假设要从 MySQL 数据库test检索以下名为emp_tbl的员工数据表。
电磁脉冲识别码 | 雇员姓名 | 二甘醇 | 薪水 | DEPT |
---|---|---|---|---|
1201 | 戈帕尔 | 技术经理 | 45000 | 它 |
1202 | 马尼沙 | 校对读者 | 45000 | 测试 |
1203 | 马斯坦瓦利 | 技术文件撰稿人 | 45000 | 它 |
1204 | 基兰 | 人力资源管理 | 40000 | 人力资源 |
1205 | 克兰蒂 | 操作管理员 | 30000 | 行政 |
使用以下代码从数据库检索数据并将其插入到电子表格中。
import java.io.File; import java.io.FileOutputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import org.apache.poi.xssf.usermodel.XSSFCell; import org.apache.poi.xssf.usermodel.XSSFRow; import org.apache.poi.xssf.usermodel.XSSFSheet; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExcelDatabase { public static void main(String[] args) throws Exception { Class.forName("com.mysql.jdbc.Driver"); Connection connect = DriverManager.getConnection( "jdbc:mysql://localhost:3306/test" , "root" , "root" ); Statement statement = connect.createStatement(); ResultSet resultSet = statement.executeQuery("select * from emp_tbl"); XSSFWorkbook workbook = new XSSFWorkbook(); XSSFSheet spreadsheet = workbook.createSheet("employe db"); XSSFRow row = spreadsheet.createRow(1); XSSFCell cell; cell = row.createCell(1); cell.setCellValue("EMP ID"); cell = row.createCell(2); cell.setCellValue("EMP NAME"); cell = row.createCell(3); cell.setCellValue("DEG"); cell = row.createCell(4); cell.setCellValue("SALARY"); cell = row.createCell(5); cell.setCellValue("DEPT"); int i = 2; while(resultSet.next()) { row = spreadsheet.createRow(i); cell = row.createCell(1); cell.setCellValue(resultSet.getInt("eid")); cell = row.createCell(2); cell.setCellValue(resultSet.getString("ename")); cell = row.createCell(3); cell.setCellValue(resultSet.getString("deg")); cell = row.createCell(4); cell.setCellValue(resultSet.getString("salary")); cell = row.createCell(5); cell.setCellValue(resultSet.getString("dept")); i++; } FileOutputStream out = new FileOutputStream(new File("exceldatabase.xlsx")); workbook.write(out); out.close(); System.out.println("exceldatabase.xlsx written successfully"); } }
让我们将上面的代码保存为ExcelDatabase.java。从命令提示符处编译并执行它,如下所示。
$javac ExcelDatabase.java $java ExcelDatabase
它将在当前目录中生成一个名为exceldatabase.xlsx的 Excel 文件,并在命令提示符下显示以下输出。
exceldatabase.xlsx written successfully
exceldatabase.xlsx文件如下所示。