Java是一种广泛使用的编程语言,而MySQL是一种流行的关系型数据库管理系统。将MySQL中的数据导出到Excel文件是一个常见的需求,通常用于数据备份、分析或共享。
以下是一个使用Java和JDBC连接MySQL数据库,并将数据导出到Excel文件的示例代码:
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public class MySQLToExcel {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/mydatabase";
String user = "username";
String password = "password";
String sql = "SELECT * FROM mytable";
try (Connection conn = DriverManager.getConnection(url, user, password);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(sql)) {
Workbook workbook = new XSSFWorkbook();
Sheet sheet = workbook.createSheet("Data");
// 创建表头
Row headerRow = sheet.createRow(0);
for (int i = 1; i <= rs.getMetaData().getColumnCount(); i++) {
Cell cell = headerRow.createCell(i - 1);
cell.setCellValue(rs.getMetaData().getColumnName(i));
}
// 填充数据
int rowNum = 1;
while (rs.next()) {
Row row = sheet.createRow(rowNum++);
for (int i = 1; i <= rs.getMetaData().getColumnCount(); i++) {
Cell cell = row.createCell(i - 1);
cell.setCellValue(rs.getString(i));
}
}
// 写入文件
try (FileOutputStream fileOut = new FileOutputStream("data.xlsx")) {
workbook.write(fileOut);
}
System.out.println("数据已成功导出到 data.xlsx 文件中。");
} catch (SQLException | IOException e) {
e.printStackTrace();
}
}
}
通过以上步骤和示例代码,你可以将MySQL中的数据导出到Excel文件,并解决常见的相关问题。
领取专属 10元无门槛券
手把手带您无忧上云