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

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

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

本文實(shí)例為大家分享了java將某個(gè)數(shù)據(jù)庫(kù)的表全部導(dǎo)出到excel中的方法,供大家參考,具體內(nèi)容如下

第一步:如何用POI操作Excel

@Test 
public void createXls() throws Exception{
 //聲明一個(gè)工作薄
 HSSFWorkbook wb = new HSSFWorkbook();
 //聲明表
 HSSFSheet sheet = wb.createSheet("第一個(gè)表");
 //聲明行
 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ù)庫(kù)的所有表

分析:

       1:某個(gè)數(shù)數(shù)據(jù)庫(kù)有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table});  - excel的文件名稱。

  2:對(duì)每一個(gè)表進(jìn)行select * 操作?!。∶恳粋€(gè)sheet的名稱。

  3:分析表結(jié)構(gòu),rs.getMetadate(); ResultSetMedated

  4:多個(gè)列,列名是什么. ?。∽侄蚊褪莝heet的第一行信息。

  5:獲取每一行的數(shù)據(jù) – 放到sheet第一行以后。

@Test
 public void export() throws Exception{
 //聲明需要導(dǎo)出的數(shù)據(jù)庫(kù)
 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ù)庫(kù)有多少表
 ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"});
 //獲取所有表名?。【褪且粋€(gè)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();
  //獲取這個(gè)查詢有多少行
  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)建一個(gè)新的列
  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"));
 }

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • 解決redisTemplate向redis中插入String類型數(shù)據(jù)時(shí)出現(xiàn)亂碼問(wèn)題

    解決redisTemplate向redis中插入String類型數(shù)據(jù)時(shí)出現(xiàn)亂碼問(wèn)題

    這篇文章主要介紹了解決redisTemplate向redis中插入String類型數(shù)據(jù)時(shí)出現(xiàn)亂碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java源碼解析CopyOnWriteArrayList的講解

    Java源碼解析CopyOnWriteArrayList的講解

    今天小編就為大家分享一篇關(guān)于Java源碼解析CopyOnWriteArrayList的講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • mybatis返回結(jié)果為Map問(wèn)題

    mybatis返回結(jié)果為Map問(wèn)題

    這篇文章主要介紹了mybatis返回結(jié)果為Map問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • SpringBoot一個(gè)非常蛋疼的無(wú)法啟動(dòng)的問(wèn)題解決

    SpringBoot一個(gè)非常蛋疼的無(wú)法啟動(dòng)的問(wèn)題解決

    這篇文章主要介紹了SpringBoot一個(gè)非常蛋疼的無(wú)法啟動(dòng)的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Java銀行取錢線程安全問(wèn)題實(shí)例分析

    Java銀行取錢線程安全問(wèn)題實(shí)例分析

    這篇文章主要介紹了Java銀行取錢線程安全問(wèn)題,結(jié)合具體實(shí)例形式分析了java使用線程操作模擬銀行取錢的相關(guān)安全問(wèn)題,需要的朋友可以參考下
    2019-09-09
  • hystrix服務(wù)降級(jí)方法使用介紹

    hystrix服務(wù)降級(jí)方法使用介紹

    什么是服務(wù)降級(jí)?當(dāng)服務(wù)器壓力劇增的情況下,根據(jù)實(shí)際業(yè)務(wù)情況及流量,對(duì)一些服務(wù)和頁(yè)面有策略的不處理或換種簡(jiǎn)單的方式處理,從而釋放服務(wù)器資源以保證核心交易正常運(yùn)作或高效運(yùn)作
    2022-09-09
  • 解析Java編程中設(shè)計(jì)模式的開(kāi)閉原則的運(yùn)用

    解析Java編程中設(shè)計(jì)模式的開(kāi)閉原則的運(yùn)用

    這篇文章主要介紹了解析Java編程中設(shè)計(jì)模式的開(kāi)閉原則的運(yùn)用,開(kāi)閉原則多應(yīng)用于Java程序的擴(kuò)展開(kāi)發(fā)方面,需要的朋友可以參考下
    2016-02-02
  • Spring中的AOP操作你了解嗎

    Spring中的AOP操作你了解嗎

    這篇文章主要為大家詳細(xì)介紹了Spring中的AOP操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • 基于java SSM springboot實(shí)現(xiàn)抗疫物質(zhì)信息管理系統(tǒng)

    基于java SSM springboot實(shí)現(xiàn)抗疫物質(zhì)信息管理系統(tǒng)

    這篇文章主要介紹了基于JAVA SSM springboot實(shí)現(xiàn)的抗疫物質(zhì)信息管理系統(tǒng),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • javaBean的基礎(chǔ)知識(shí)及常見(jiàn)亂碼解決方法

    javaBean的基礎(chǔ)知識(shí)及常見(jiàn)亂碼解決方法

    這篇文章主要介紹了javaBean的基礎(chǔ)知識(shí)及常見(jiàn)亂碼解決方法的相關(guān)資料,需要的朋友可以參考下
    2017-03-03

最新評(píng)論