java導(dǎo)出數(shù)據(jù)庫的全部表到excel
本文實例為大家分享了java將某個數(shù)據(jù)庫的表全部導(dǎo)出到excel中的方法,供大家參考,具體內(nèi)容如下
第一步:如何用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); //寫入數(shù)據(jù) cel.setCellValue("你也好"); FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls"); wb.write(fileOut); fileOut.close(); }
第二步:導(dǎo)出指定數(shù)據(jù)庫的所有表
分析:
1:某個數(shù)數(shù)據(jù)庫有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}); - excel的文件名稱。
2:對每一個表進(jìn)行select * 操作?!。∶恳粋€sheet的名稱。
3:分析表結(jié)構(gòu),rs.getMetadate(); ResultSetMedated
4:多個列,列名是什么. ?。∽侄蚊褪莝heet的第一行信息。
5:獲取每一行的數(shù)據(jù) – 放到sheet第一行以后。
@Test public void export() throws Exception{ //聲明需要導(dǎo)出的數(shù)據(jù)庫 String dbName = "focus"; //聲明book HSSFWorkbook book = new HSSFWorkbook(); //獲取Connection,獲取db的元數(shù)據(jù) Connection con = DataSourceUtils.getConn(); //聲明statemen Statement st = con.createStatement(); //st.execute("use "+dbName); DatabaseMetaData dmd = con.getMetaData(); //獲取數(shù)據(jù)庫有多少表 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; //查詢數(shù)據(jù) rs = st.executeQuery(sql); //根據(jù)查詢的結(jié)果,分析結(jié)果集的元數(shù)據(jù) ResultSetMetaData rsmd = rs.getMetaData(); //獲取這個查詢有多少行 int cols = rsmd.getColumnCount(); //獲取所有列名 //創(chuàng)建第一行 HSSFRow row = sheet.createRow(0); for(int i=0;i<cols;i++){ String colName = rsmd.getColumnName(i+1); //創(chuàng)建一個新的列 HSSFCell cell = row.createCell(i); //寫入列名 cell.setCellValue(colName); } //遍歷數(shù)據(jù) 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); //放數(shù)據(jù) cel.setCellValue(val); } } } con.close(); book.write(new FileOutputStream("d:/a/"+dbName+".xls")); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
相關(guān)文章
JpaRepository如何實現(xiàn)增刪改查并進(jìn)行單元測試
這篇文章主要介紹了JpaRepository如何實現(xiàn)增刪改查并進(jìn)行單元測試,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11解決在Gradle/IDEA中無法正常使用readLine的問題原因
這篇文章主要介紹了在Gradle/IDEA中無法正常使用readLine的解決方法,原因是由于Gradle的標(biāo)準(zhǔn)輸入默認(rèn)并不與系統(tǒng)標(biāo)準(zhǔn)輸入綁定,需手動設(shè)置,需要的朋友可以參考下2021-12-12IntelliJ IDEA中出現(xiàn)"PSI and index do not match"錯誤的解決辦法
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA中出現(xiàn)"PSI and index do not match"錯誤的解決辦法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10