程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java導出數據庫的全體表到excel

java導出數據庫的全體表到excel

編輯:關於JAVA

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"));
 }

以上就是本文的全體內容,願望對年夜家的進修有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved