使用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;
}
}
四、結果截圖
五、總結
這樣就實現了數據庫表的導出,有什麼疑問留言哦,謝謝大家的觀看!!!