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 파일은 다음과 같습니다.