Apache POI-데이터베이스
이 장에서는 POI 라이브러리가 데이터베이스와 상호 작용하는 방법에 대해 설명합니다. JDBC의 도움으로 데이터베이스에서 데이터를 검색하고 POI 라이브러리를 사용하여 해당 데이터를 스프레드 시트에 삽입 할 수 있습니다. SQL 작업을위한 MySQL 데이터베이스를 고려해 보겠습니다.
데이터베이스에서 Excel로 쓰기
다음과 같은 직원 데이터 테이블을 가정 해 보겠습니다. emp_tbl MySQL 데이터베이스에서 검색됩니다. test.
EMP ID | EMP 이름 | DEG | 봉급 | DEPT |
---|---|---|---|---|
1201 | 고팔 | 기술 관리자 | 45000 | 그것 |
1202 | 마니 샤 | 증거 판독기 | 45000 | 테스팅 |
1203 년 | Masthanvali | 기술 작가 | 45000 | 그것 |
1204 | Kiran | 시간 관리자 | 40000 | HR |
1205 년 | Kranthi | 운영 관리자 | 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
이름이 Excel 파일을 생성합니다. exceldatabase.xlsx 현재 디렉토리에서 명령 프롬프트에 다음 출력을 표시합니다.
exceldatabase.xlsx written successfully
그만큼 exceldatabase.xlsx 파일은 다음과 같습니다.