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

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

第一步:如何用POI操作Excel

@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第一行以后。

@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"));
 }

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

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索java导出表到excel
mysql导出全部数据库、oracle数据库全部导出、java数据库导出excel、java 数据库导出csv、java导出mysql数据库,以便于您获取更多的相关知识。

时间: 2024-09-26 07:37:13

java导出数据库的全部表到excel_java的相关文章

mysql 导入导出数据库、数据表的方法_Mysql

Linux下均在控制台下操作.导入数据库:前提:数据库和数据表要存在(已经被创建) (1)将数据表 test_user.sql 导入到test 数据库的test_user 表中[root@test ~]# mysql -uroot -p test < /www/web/test/test_user.sql (2) 将数据库 test.sql 导入到 test 数据库test 中[root@test ~]# mysql -uroot -p test < /www/web/test/test.sq

Mysql 导出数据库和指定表中的数据

参考地址:http://jingyan.baidu.com/article/b7001fe14240ab0e7282dde9.html [root@youo zw]# mysqldump -u root -p IpManage_v2 > zw_ipmanagev2.sql; 唉哟,不错哦!   MySQL导出指定表中的数据 要求: 1. 不导出创表的语句,因为表已经建好:默认会导出,先drop table然后create table: 2. 导出的insert语句加上ignore,允许重复执行:

mysql 添加用户,授权,远程登陆,远程导入导出数据库,用户及权限查询,新增用户无法登陆,

首先提示一点,当使用新增用户登陆失败: root@controller:~# mysql -h localhost -ukeystone -ppassword  ERROR 1045 (28000): Access denied for user 'keystone'@'localhost' (using password: YES)解决方法:  增加普通用户后,执行:  mysql> use mysql mysql> delete from user where user=''; mysql

java如何实现远程备份与还原ORACLE数据库中的表

问题描述 java如何实现远程备份与还原ORACLE数据库中的表 本地没有装ORACLE数据库,项目是B/S模式的,想在页面加上两个按钮"备份数据","还原数据" 每台客户端不可能都装ORACLE数据库 解决方案 在应用服务器端装个oracle客户端,然后用java的外部命令调用方式.解决方案二:如果是个别业务表的数据需要备份和还原可以自己写个导出.导入的功能.(导出的数据可以组织成有格式的文本或者XML)如果是全部表的备份和还原,建议还是人工用命令去操作好.解决方

mysql-《疯狂java实战演义》里面的第十三章MySQL管理器程序有没有做出往数据库导入Excel表的?

问题描述 <疯狂java实战演义>里面的第十三章MySQL管理器程序有没有做出往数据库导入Excel表的? 本人想在MySQL管理器程序源代码里面加上导入表的代码,但是总是失败,想向个位请教一下,有人这么做过吗,能否给一下代码,谢谢! 解决方案 http://download.csdn.net/detail/qianfu123/3589697 源代码,自己下

mysql-请问php与msql网站源码打包时,需要将数据库里面的表导出吗?

问题描述 请问php与msql网站源码打包时,需要将数据库里面的表导出吗? 如果不导出mysql的表,那么对方是不是就不能正确访问数据库? 现在一般怎样将数据库传给客户方呢? 解决方案 一般是做一个建库的脚本和一个install.php,用户首次运行,就执行它,它负责初始化数据库.稍微友好一些,先让用户填写相关数据库的参数. 解决方案二: 不错,不错!

java oracle-怎么在oracle用imp导入数据库前删除数据库里的表 触发器怎么写 或者java代码怎么写

问题描述 怎么在oracle用imp导入数据库前删除数据库里的表 触发器怎么写 或者java代码怎么写 // 还原 Button button_1 = new Button(composite_1, SWT.NONE); button_1.addSelectionListener(new SelectionAdapter() { @Override public void widgetSelected(SelectionEvent e) { TableItem[] tis = table.get

erwin如果导出数据库表结构为xml格式文件

问题描述 erwin如果导出数据库表结构为xml格式文件 erwin如果导出数据库表结构为xml格式文件,现已经连接oracle数据库 导入表显示模型了,我需要erwin这些表结构用于数据采集 解决方案 http://blog.itpub.net/134308/viewspace-140582/ 解决方案二: 用powerdesigner可以搞 解决方案三: 谢谢 我已经导出来文件啦 erwin里面有save as 点击可以保存为xml格式的文件 供大家分享

oracle导出的数据库占用20G表空间

问题描述 oracle导出的数据库占用20G表空间 alter system set deferred_segment_creation=false scope=both; select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 exp posko/globalsoft@orcl file=d:pos1601.dmp owner=(posko) compress=n imp