本文實例為大家分享了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")); }以上就是本文的全部內容,希望對大家的學習有所幫助。