在路上

 找回密码
 立即注册
在路上 站点首页 学习 查看内容

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

2016-8-29 13:20| 发布者: zhangjf| 查看: 567| 评论: 0

摘要: 本文实例为大家分享了java将某个数据库的表全部导出到excel中的方法,供大家参考,具体内容如下 第一步:如何用POI操作Excel @test public void createXls() throws Exception{ //声明一个工作薄 HSSFWorkbook wb ...

本文实例为大家分享了java将某个数据库的表全部导出到excel中的方法,供大家参考,具体内容如下

第一步:如何用POI操作Excel

  1. [url=home.php?mod=space&uid=5447]@test[/url]
  2. public void createXls() throws Exception{
  3. //声明一个工作薄
  4. HSSFWorkbook wb = new HSSFWorkbook();
  5. //声明表
  6. HSSFSheet sheet = wb.createSheet("第一个表");
  7. //声明行
  8. HSSFRow row = sheet.createRow(7);
  9. //声明列
  10. HSSFCell cel = row.createCell(3);
  11. //写入数据
  12. cel.setCellValue("你也好");
  13. FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls");
  14. wb.write(fileOut);
  15. fileOut.close();
  16. }
复制代码

第二步:导出指定数据库的所有表

分析:

1:某个数数据库有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}); - excel的文件名称。

  2:对每一个表进行select * 操作。 - 每一个sheet的名称。

  3:分析表结构,rs.getMetadate(); ResultSetMedated

  4:多个列,列名是什么.  - 字段名就是sheet的第一行信息。

  5:获取每一行的数据 – 放到sheet第一行以后。

  1. @Test
  2. public void export() throws Exception{
  3. //声明需要导出的数据库
  4. String dbName = "focus";
  5. //声明book
  6. HSSFWorkbook book = new HSSFWorkbook();
  7. //获取Connection,获取db的元数据
  8. Connection con = DataSourceUtils.getConn();
  9. //声明statemen
  10. Statement st = con.createStatement();
  11. //st.execute("use "+dbName);
  12. DatabaseMetaData dmd = con.getMetaData();
  13. //获取数据库有多少表
  14. ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"});
  15. //获取所有表名 - 就是一个sheet
  16. List<String> tables = new ArrayList<String>();
  17. while(rs.next()){
  18. String tableName = rs.getString("TABLE_NAME");
  19. tables.add(tableName);
  20. }
  21. for(String tableName:tables){
  22. HSSFSheet sheet = book.createSheet(tableName);
  23. //声明sql
  24. String sql = "select * from "+dbName+"."+tableName;
  25. //查询数据
  26. rs = st.executeQuery(sql);
  27. //根据查询的结果,分析结果集的元数据
  28. ResultSetMetaData rsmd = rs.getMetaData();
  29. //获取这个查询有多少行
  30. int cols = rsmd.getColumnCount();
  31. //获取所有列名
  32. //创建第一行
  33. HSSFRow row = sheet.createRow(0);
  34. for(int i=0;i<cols;i++){
  35. String colName = rsmd.getColumnName(i+1);
  36. //创建一个新的列
  37. HSSFCell cell = row.createCell(i);
  38. //写入列名
  39. cell.setCellValue(colName);
  40. }
  41. //遍历数据
  42. int index = 1;
  43. while(rs.next()){
  44. row = sheet.createRow(index++);
  45. //声明列
  46. for(int i=0;i<cols;i++){
  47. String val = rs.getString(i+1);
  48. //声明列
  49. HSSFCell cel = row.createCell(i);
  50. //放数据
  51. cel.setCellValue(val);
  52. }
  53. }
  54. }
  55. con.close();
  56. book.write(new FileOutputStream("d:/a/"+dbName+".xls"));
  57. }
复制代码

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

最新评论

小黑屋|在路上 ( 蜀ICP备15035742号-1 

;

GMT+8, 2025-7-7 01:08

Copyright 2015-2025 djqfx

返回顶部