अपाचे POI - डेटाबेस

यह अध्याय बताता है कि POI लाइब्रेरी डेटाबेस के साथ कैसे इंटरैक्ट करती है। JDBC की मदद से, आप डेटाबेस से डेटा पुनः प्राप्त कर सकते हैं और POI लाइब्रेरी का उपयोग करके उस डेटा को एक स्प्रेडशीट में सम्मिलित कर सकते हैं। आइए SQL ऑपरेशन के लिए MySQL डेटाबेस पर विचार करें।

डेटाबेस से एक्सेल में लिखें

हमें निम्नलिखित कर्मचारी डेटा टेबल कहा जाता है emp_tbl MySQL डेटाबेस से पुनर्प्राप्त किया जाना है test

ईएमपी आईडी ईएमपी नाम डीईजी वेतन विभाग
1201 गोपाल तकनीक प्रबंधक 45,000 आईटी
1202 मनीषा प्रमाण पाठक 45,000 परिक्षण
1203 Masthanvali तकनीकी लेखक 45,000 आईटी
1204 किरण प्रशासन 40000 मानव संसाधन
1205 क्रांति Op व्यवस्थापक 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 अपनी वर्तमान निर्देशिका में और कमांड प्रॉम्प्ट पर निम्न आउटपुट प्रदर्शित करें।

exceldatabase.xlsx written successfully

exceldatabase.xlsx फ़ाइल निम्नानुसार है।