激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - java導(dǎo)出數(shù)據(jù)庫(kù)的全部表到excel

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

2020-04-10 15:27lijiao JAVA教程

這篇文章主要為大家詳細(xì)介紹了java導(dǎo)出數(shù)據(jù)庫(kù)的全部表到excel的相關(guān)資料,感興趣的小伙伴們可以參考一下

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

第一步:如何用POI操作Excel

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@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);
  //寫(xiě)入數(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的文件名稱(chēng)。

  2:對(duì)每一個(gè)表進(jìn)行select * 操作。 - 每一個(gè)sheet的名稱(chēng)。

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

  4:多個(gè)列,列名是什么.  - 字段名就是sheet的第一行信息。

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
@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;
   //查詢(xún)數(shù)據(jù)
   rs = st.executeQuery(sql);
   //根據(jù)查詢(xún)的結(jié)果,分析結(jié)果集的元數(shù)據(jù)
   ResultSetMetaData rsmd = rs.getMetaData();
   //獲取這個(gè)查詢(xún)有多少行
   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);
    //寫(xiě)入列名
    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í)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲无线看 | 久久久精彩 | 国产精品久久久久永久免费观看 | 欧洲精品视频在线观看 | 国产免费视频一区二区裸体 | 成人毛片100部 | 日本aaa一级片 | 爽毛片| 久久国产精品区 | 欧美熟videos肥婆 | 欧美特黄特色视频 | 久久55| 欧美精品一区自拍a毛片在线视频 | 日韩精品免费看 | 亚州欧美视频 | 成人短视频在线播放 | 蜜桃久久一区二区三区 | 99视频在线观看视频 | 成人午夜免费av | 91久久九色 | 欧美爱爱视频免费看 | 欧美亚洲国产一区 | 国产成人精品一区二区视频免费 | 色柚视频网站ww色 | 逼片 | 制服丝袜日日夜夜 | 久久久资源网 | 成人午夜免费av | 黄视频在线网站 | 久久久一区二区精品 | 99精品国产一区二区三区 | 韩国精品视频在线观看 | 久久国产精品一区 | a在线视频 | 欧美精品18 | 91九色网址 | 中国大陆一级毛片 | 欧美黄色小视频 | 国产电影av在线 | 奇米影视亚洲春色 | 欧美 国产 亚洲 卡通 综合 |