服务器之家

服务器之家 > 正文

java导出数据库的全部表到excel

时间:2020-04-10 15:27     来源/作者:lijiao

本文实例为大家分享了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"));
 }

以上就是本文的全部内容,希望对大家的学习有所帮助。

标签:

相关文章

热门资讯

沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部