一、需求

我們會遇到開發任務:

經理:小王,你來做一下把資料庫裡的資料匯出到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;
}
}

四、結果截圖

五、總結

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