欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java導(dǎo)出數(shù)據(jù)庫的全部表到excel

 更新時間:2020年11月25日 15:28:06   投稿:lijiao  
這篇文章主要為大家詳細(xì)介紹了java導(dǎo)出數(shù)據(jù)庫的全部表到excel的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了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)文章

  • JFinal極速開發(fā)框架使用筆記分享

    JFinal極速開發(fā)框架使用筆記分享

    下面小編就為大家分享一篇JFinal極速開發(fā)框架使用筆記,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • SpringBoot超詳細(xì)講解yaml配置文件

    SpringBoot超詳細(xì)講解yaml配置文件

    這篇文章主要介紹了SpringBoot中的yaml配置文件問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 教你使用springboot配置多數(shù)據(jù)源

    教你使用springboot配置多數(shù)據(jù)源

    發(fā)現(xiàn)有很多小伙伴還不會用springboot配置多數(shù)據(jù)源,今天特地給大家整理了本篇文章,文中有非常詳細(xì)的圖文介紹及代碼示例,對正在學(xué)習(xí)java的小伙伴很有幫助,需要的朋友可以參考下
    2021-05-05
  • JpaRepository如何實現(xiàn)增刪改查并進(jìn)行單元測試

    JpaRepository如何實現(xiàn)增刪改查并進(jìn)行單元測試

    這篇文章主要介紹了JpaRepository如何實現(xiàn)增刪改查并進(jìn)行單元測試,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 解決在Gradle/IDEA中無法正常使用readLine的問題原因

    解決在Gradle/IDEA中無法正常使用readLine的問題原因

    這篇文章主要介紹了在Gradle/IDEA中無法正常使用readLine的解決方法,原因是由于Gradle的標(biāo)準(zhǔn)輸入默認(rèn)并不與系統(tǒng)標(biāo)準(zhǔn)輸入綁定,需手動設(shè)置,需要的朋友可以參考下
    2021-12-12
  • Java之單例設(shè)計模式示例詳解

    Java之單例設(shè)計模式示例詳解

    這篇文章主要介紹了Java之單例設(shè)計模式示例詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Java十大經(jīng)典排序算法的實現(xiàn)圖解

    Java十大經(jīng)典排序算法的實現(xiàn)圖解

    Java常見的排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數(shù)排序等。本文詳解介紹Java十大十大經(jīng)典排序算法的實現(xiàn)以及圖解,需要的可以參考一下
    2022-03-03
  • IntelliJ IDEA中出現(xiàn)

    IntelliJ 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
  • Java中常用的設(shè)計模式之責(zé)任鏈模式詳解

    Java中常用的設(shè)計模式之責(zé)任鏈模式詳解

    這篇文章主要為大家詳細(xì)介紹了Java中常用的設(shè)計模式之責(zé)任鏈模式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • Springcloud之Gateway組件詳解

    Springcloud之Gateway組件詳解

    Spring Cloud Gateway是Spring Cloud微服務(wù)生態(tài)下的網(wǎng)關(guān)組件。Spring Cloud Gateway是基于Spring 5和Spring Boot 2搭建的,本質(zhì)上是一個Spring Boot應(yīng)用。本文詳細(xì)介紹了SpringCloud的網(wǎng)關(guān)組件 Gateway,,需要的朋友可以參考下
    2023-05-05

最新評論