java導出數據庫的全體表到excel。本站提示廣大學習愛好者:(java導出數據庫的全體表到excel)文章只能為提供參考,不一定能成為您想要的結果。以下是java導出數據庫的全體表到excel正文
本文實例為年夜家分享了java將某個數據庫的表全體導出到excel中的辦法,供年夜家參考,詳細內容以下
第一步:若何用POI操作Excel
@Test
public void createXls() throws Exception{
//聲明一個任務薄
HSSFWorkbook wb = new HSSFWorkbook();
//聲明表
HSSFSheet sheet = wb.createSheet("第一個表");
//聲明行
HSSFRow row = sheet.createRow(7);
//聲明列
HSSFCell cel = row.createCell(3);
//寫入數據
cel.setCellValue("你也好");
FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls");
wb.write(fileOut);
fileOut.close();
}
第二步:導出指定命據庫的一切表
剖析:
1:某個數數據庫有若干表,表名是甚麼?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}); - excel的文件稱號。
2:對每個表停止select * 操作。 - 每個sheet的稱號。
3:剖析表構造,rs.getMetadate(); ResultSetMedated
4:多個列,列名是甚麼. - 字段名就是sheet的第一行信息。
5:獲得每行的數據 – 放到sheet第一行今後。
@Test
public void export() throws Exception{
//聲明須要導出的數據庫
String dbName = "focus";
//聲明book
HSSFWorkbook book = new HSSFWorkbook();
//獲得Connection,獲得db的元數據
Connection con = DataSourceUtils.getConn();
//聲明statemen
Statement st = con.createStatement();
//st.execute("use "+dbName);
DatabaseMetaData dmd = con.getMetaData();
//獲得數據庫有若干表
ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"});
//獲得一切表名 - 就是一個sheet
List<String> tables = new ArrayList<String>();
while(rs.next()){
String tableName = rs.getString("TABLE_NAME");
tables.add(tableName);
}
for(String tableName:tables){
HSSFSheet sheet = book.createSheet(tableName);
//聲明sql
String sql = "select * from "+dbName+"."+tableName;
//查詢數據
rs = st.executeQuery(sql);
//依據查詢的成果,剖析成果集的元數據
ResultSetMetaData rsmd = rs.getMetaData();
//獲得這個查詢有若干行
int cols = rsmd.getColumnCount();
//獲得一切列名
//創立第一行
HSSFRow row = sheet.createRow(0);
for(int i=0;i<cols;i++){
String colName = rsmd.getColumnName(i+1);
//創立一個新的列
HSSFCell cell = row.createCell(i);
//寫出列名
cell.setCellValue(colName);
}
//遍歷數據
int index = 1;
while(rs.next()){
row = sheet.createRow(index++);
//聲明列
for(int i=0;i<cols;i++){
String val = rs.getString(i+1);
//聲明列
HSSFCell cel = row.createCell(i);
//放數據
cel.setCellValue(val);
}
}
}
con.close();
book.write(new FileOutputStream("d:/a/"+dbName+".xls"));
}
以上就是本文的全體內容,願望對年夜家的進修有所贊助。