使用POI把查詢到的數據表數據導出到Excel中,一個表一個sheet.最詳細!!!

一、需求

我們會遇到開發任務:
經理:小王,你來做一下把數據庫里的數據導出到Excel中,一個表是一個sheet,不要一個表一個Excel.
小王:好的,經理.(內心一臉懵逼)

二、前期準備

首先我們採用Apache的POI來實現Excel的導出功能,
導入直通車—> 使用POI+hutool實現導入Excel
我們把maven依賴先準備好:

	<!-- 導出為Excel所需依賴 -->
      <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi</artifactId>
          <version>3.9</version>
      </dependency>
      <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi-ooxml</artifactId>
          <version>3.9</version>
      </dependency>
      <!-- 工具包 -->
        <dependency>
            <groupId>commons-dbutils</groupId>
            <artifactId>commons-dbutils</artifactId>
            <version>1.6</version>
        </dependency>

三、代碼演示

  • 首先我們先使用JDBC結合Dbutils把要導出的數據庫表數據準備好
    /**
    * 利用jdbc來把要導出的數據表查詢出來
    * @return
    */
   public static Map<String,List<Map<String, Object>>> getDataSource(){

       Connection con = null;
       Statement sta = null;
       try {
           //1.註冊驅動==》告訴指揮部有哪些造橋人可以調遣
           Class.forName("com.mysql.cj.jdbc.Driver");

           //這裡是mysql為例   oracle的url ---"jdbc:oracle:thin:@localhost:1521:orcl"
           String url = "jdbc:mysql://127.0.0.1:3306/test";
           String user = "root";
           String pwd =  "root";

           //2.獲得鏈接==》指揮部根據傳入類型 調遣不同的造橋的人造橋
           con = DriverManager.getConnection(url,user,pwd);
           //3.創建Statement對象===》造車
           sta = con.createStatement();
           //4.執行SQL ==》運行SQL 有結果返回
           String sql = "select * from user";
           String sql1 = "select * from test";

           //第五步處理結果還可以引入Dbutils工具包來解析結果
           QueryRunner queryRunner = new QueryRunner();

           //存放查詢出來的數據,key為表名,value為查詢出來的表字段和對應的值
           Map<String,List<Map<String, Object>>> mapMap = new HashMap<>();
           
           List<Map<String, Object>> query = queryRunner.query(con, sql, new MapListHandler());

           List<Map<String, Object>> query1 = queryRunner.query(con, sql1, new MapListHandler());

           //暫時以兩張表為例,多張一個意思
           mapMap.put("user",query);
           mapMap.put("test",query1);

           return mapMap;

       } catch (ClassNotFoundException | SQLException e) {
           e.printStackTrace();
           return null;
       }finally {
           //6.關閉資源
           DbUtils.closeQuietly(sta);//Dbutils封裝了關閉方法
           DbUtils.closeQuietly(con);
       }
   }
  • 接下來我們把這些數據庫表數據導出到Excel
    /**
    * 把準備好的數據庫表數據導出到本地Excel中
    */
   public boolean exportExcel() {

       //拿到數據庫表的所有信息,開始導出
       Map<String, List<Map<String, Object>>> source = getDataSource();

       //創建一個Excel模板
       Workbook workbook = new XSSFWorkbook();

       for (Map.Entry<String,List<Map<String, Object>>> mapTop :source.entrySet()) {
           //獲取sheet的名字  以表名來命名
           String sheetName = mapTop.getKey();
           //創建sheet
           Sheet sheet = workbook.createSheet(sheetName);
           //創建第一行
           Row header = sheet.createRow(0);
           //從第二行開始 --來控制插入的行數
           int rowSize = 1;
           //便利每個表的數據
           for (Map<String, Object> button : mapTop.getValue()){
               //控制第一行的列
               int columnSize = 0;
               //給第一行表頭賦值
               for (String string :button.keySet()){
                   //把表頭添加上
                   header.createCell(columnSize++).setCellValue(string);
               }
               //控制從第二行開始插入數據的列
               int valueSize = 0;

               //創建第二行   每添加完一行+1
               Row data = sheet.createRow(rowSize++);

               //從第二行開始都是數據
               for (Object object : button.values() ){
                   //防止有的列為空
                   if (object != null) {
                       data.createCell(valueSize++).setCellValue(object.toString());
                   }else {
                       data.createCell(valueSize++).setCellValue("");
                   }
               }
           }
       }
       try {
           File file = new File("E:/template/數據庫表數據.xlsx");
           if (file.exists()){
               file.delete();//存在就刪除
           }
           //保存到本地
           FileOutputStream fos = new FileOutputStream("E:/template/數據庫表數據.xlsx");
           workbook.write(fos);
           fos.close();
           //存在就代表成功
           return file.exists();
       } catch (Exception e) {
           e.printStackTrace();
           return false;
       }
   }

四、結果截圖

在這裡插入圖片描述

五、總結

這樣就實現了數據庫表的導出,有什麼疑問留言哦,謝謝大家的觀看!!!

Tags: