一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

服務器之家 - 編程語言 - JAVA教程 - java導出數據庫的全部表到excel

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

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

這篇文章主要為大家詳細介紹了java導出數據庫的全部表到excel的相關資料,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java將某個數據庫的表全部導出到excel中的方法,供大家參考,具體內容如下

第一步:如何用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{
  //聲明一個工作薄
  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第一行以后。

?
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{
  //聲明需要導出的數據庫
  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"));
 }

以上就是本文的全部內容,希望對大家的學習有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩欧美中文在线 | 色噜噜国产精品视频一区二区 | 国产成人无精品久久久久国语 | 9966久久精品免费看国产 | 欧美灰丝袜丝交nylons | 毛片免费视频观看 | 无限资源在线观看完整版免费下载 | 国内久久| 精品99在线观看 | 视频大全在线观看免费 | 91精品国产色综合久久 | 3d动漫h在线观看网站蜜芽 | 精品无码国产污污污免费网站2 | 日韩高清在线观看 | 2048论坛永久入口 原创合集 | 日本妇人成熟免费不卡片 | zol中关村在线官网 yy6080欧美三级理论 | 图片一区 | 暖暖日本在线观看免费 | 丝袜兔女郎被啪在线观看91 | 精品视频免费在线 | 182免费在线观看 | 色综合色狠狠天天久久婷婷基地 | 国产午夜精品一区二区三区不卡 | 幻女free性摘花第一次 | 久久久WWW免费人成精品 | 国产精品吹潮香蕉在线观看 | 日韩欧美推理片免费在线播放 | 7mav视频| avtt一区| 亚洲va天堂va国产va久久 | 操闺蜜| 久草在线草a免费线看 | 九九在线精品视频 | www.四虎com | 男男gaygays中国 | 日本一区二区视频在线观看 | h视频免费高清在线观看 | 无码天堂亚洲国产AV久久 | 美女私人影院 | 亚洲欧美一区二区三区在饯 |