一般的数据库数据怎么导入excel中呢??这让人非常疑惑,今天我找到了一个方法能够实现

须要导入一个第三方包下载地址

详细内容例如以下:

里面含有指导文档,index.html里面含有怎样读取数据库文件到excel和excel数据到数据库中。

主要用到一个包

将这个包复制到项目里面就能够了。

先做一个简单版本号的helloword

<span style="white-space:pre">	</span>public void mkexcel() throws Exception{
//首先在内存中建立好工作薄
HSSFWorkbook book =new HSSFWorkbook();//建立好工作薄
HSSFSheet sheet = book.createSheet("表一");//表单名以及表单
HSSFRow row=sheet.createRow(4);//创建行数
HSSFCell cell=row.createCell(4);//创建列数
cell.setCellValue("大哥哥。加油!! ");//将数据写到cell中去
//内存中建立可不行。必需要写到文件
FileOutputStream out =new FileOutputStream("a.xls");
book.write(out);
}

效果图:

通过上面的简单实例,我们能发现,创建xls的文件类似于在网页中动态创建table表格类似点击打开链接

1。建立工作薄

2,薄建立表

3。表建行

4。行建列

5,列里面设值



有了上面的这个简单的介绍,如今開始导入数据库里面的内容

1,我们必须从内存中建立工作薄

<span style="font-size:18px; white-space: pre;">	</span><span style="font-size:24px;">HSSFWorkbook book =new HSSFWorkbook();</span>

2,创建sheet的时候。我们须要指定sheet名,全部须要用到元数据得到database里面的table名

Connection con =hibernateFactory2.getCon();//数据库连接成功

DatabaseMetaData dmeta=con.getMetaData();//元数据


<span style="font-size:24px;">ResultSet rs=dmeta.getCatalogs();//获得全部的数据库,可是为了方便。我们直接指定数据库名</span>

3。获得table名。

<span style="white-space:pre">		</span>String dName="hncu";
//获得数据库里面的表名,返回ResultSet 所有放在list中
ResultSet rs= dmeta.getTables(dName, dName, null, new String[]{"TABLE"});
//放在list 中,为后面的sheet名
List<String > list =new ArrayList<String>();
while(rs.next())
{
<span style="white-space: pre;"> </span>list.add(rs.getString("TABLE_NAME"));//找出表名将其放入list 中
}

4,開始建立sheet表单。同一时候採用元素据生成表头

<span style="white-space:pre">	<span style="font-size:24px;">		</span></span><span style="font-size:24px;">for(String sheetname:list){
HSSFSheet sheet=book.createSheet(sheetname);//设置表单和表单名
String sql="select * from "+dName+"."+sheetname;//以数据库的名字.表名来获取
Statement st =con.createStatement();
ResultSet rs2=st.executeQuery(sql);
ResultSetMetaData rsmd=rs2.getMetaData();
int col =rsmd.getColumnCount();//获得有多少列 //生成表单的第一行,表头
HSSFRow row0 =sheet.createRow(0);
for(int i=0;i<col;i++){
HSSFCell cell = row0.createCell(i);
cell.setCellValue(rsmd.getColumnName(i+1));
}</span>

5,创建行和列以及设置行列的值

<span style="white-space:pre">			</span>int idx=1;//用来生成行
//第一头部分完毕 //完毕第二部分
while(rs2.next()){
HSSFRow row =sheet.createRow(idx++);//一行创建完毕。開始创建列
for(int i =0 ;i<col;i++){
HSSFCell cell =row.createCell(i);
cell.setCellValue(rs2.getString(i+1));
}
}
}

6,存到文件

	<span style="white-space:pre">	</span><span style="font-size:24px;">FileOutputStream out =new FileOutputStream("db.xls");
<span style="white-space:pre"> </span> book.write(out);//採用book来进行写</span>

能直接执行的代码

public void Test3() throws Exception{
/*
* 要先得到数据库里面的数据。我们必须採用元数据,获得想关的内容
* 要是直接执行,须要导包 建立数据库,查看的生成后文件在和根文件夹src同级
*/ //先从内存中的数据建立
HSSFWorkbook book =new HSSFWorkbook();
Connection con =hibernateFactory2.getCon();//数据库连接
DatabaseMetaData dmeta=con.getMetaData();//元素据
// ResultSet rs=dmeta.getCatalogs();//获得所有的数据库
String dName="hncu";
//获得数据库里面的表名,返回ResultSet 所有放在list中
ResultSet rs= dmeta.getTables(dName, dName, null, new String[]{"TABLE"});
//放在list 中,为后面的sheet名
List<String > list =new ArrayList<String>();
while(rs.next())
{
list.add(rs.getString("TABLE_NAME"));//找出表名将其放入list 中
}
for(String sheetname:list){
HSSFSheet sheet=book.createSheet(sheetname);//设置表单和表单名
String sql="select * from "+dName+"."+sheetname;//以数据库的名字.表名来获取
Statement st =con.createStatement();
ResultSet rs2=st.executeQuery(sql);
ResultSetMetaData rsmd=rs2.getMetaData();
int col =rsmd.getColumnCount();//获得有多少列 //生成表单的第一行
HSSFRow row0 =sheet.createRow(0);
for(int i=0;i<col;i++){
HSSFCell cell = row0.createCell(i);
cell.setCellValue(rsmd.getColumnName(i+1));
}
int idx=1;
//第一头部分完毕 //完毕第二部分
while(rs2.next()){
HSSFRow row =sheet.createRow(idx++);//一行创建完毕。開始创建列
for(int i =0 ;i<col;i++){
HSSFCell cell =row.createCell(i);
cell.setCellValue(rs2.getString(i+1));
}
}
}
FileOutputStream out =new FileOutputStream("db.xls");
book.write(out);

就这样就将数据所有导入到excel里面了

效果图:

数据库中的数据

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

导出的excel的数据



可以全然导出来,可是在实验的时候。数据库类型为blob类型的不能导出,由于excel 的每一个单元格的数据不支持那么大的。

有什么问题,大家一起提出来,共同讨论下。谢谢

Java将数据库数据导入EXCEL的更多相关文章

  1. JAVA实现数据库数据导入/导出到Excel(POI)

    准备工作: 1.导入POI包:POI下载地址http://mirrors.tuna.tsinghua.edu.cn/apache/poi/release/src/(重要) 如下 2.导入Java界面美 ...

  2. java数据库数据导入excel

    data导出入excel中 controller: package com.longfor.hrssc.api.controller; import com.longfor.hrssc.api.mod ...

  3. ASP.NET中数据库数据导入Excel并打印(2)

    大家可能觉得上面的代码比较复杂,因为上面对于对打印要求比较高的应用,是十分有效的.如果只是单单对数据进行导出,还可以使用简单的格式,比如使用以下的代码:      Private Sub Page_L ...

  4. 在java中实现数据导入excel表格中

    1.首先前端代码如下: 一个导出按钮:<input id="export" class="btn btn-primary" type="butt ...

  5. PHP把数据库数据导入Excel

    <?php function xlsBOF() { echo pack("ssssss", 0x809, 0x8, 0x0, 0x10, 0x0, 0x0); return; ...

  6. [Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!

    引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...

  7. 转:[Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!

    引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...

  8. Java实现大批量数据导入导出(100W以上) -(三)超过25列Excel导出

    前面一篇文章介绍大数据量导出实现: Java实现大批量数据导入导出(100W以上) -(二)导出 这篇文章在Excel列较少时,按以上实际验证能很快实现生成.但如果列较多时用StringTemplat ...

  9. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])    本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较   ...

随机推荐

  1. IOS Xib使用——Xib表示局部界面

    Xib文件是一个轻量级的用来描述局部界面的文件,在之前的文章讲解了为控制器添加Xib文件,本节主要讲解一下通过xib文件表示局部界面. <一> 创建Xib文件 Xib文件创建的时候是选择U ...

  2. elasticSearch nested exist与missing查询

    elasticSearch nested查询,简单意义上,你可以理解为,它不会被索引,只是被暂时隐藏起来,而查询的时候,开关就是使用nested query/filter去查询 下面我有一个例子,是查 ...

  3. System.ComponentModel.Component : MarshalByRefObject, IComponent, IDisposable

    #region 程序集 System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 // C:\Windows\ ...

  4. [Algorithm] Write your own Math.pow function in Javascript, using Recursive approach

    /**@abstract * Write your own Math.pow(a int, b int) function * */ function pow (a, b) { let result ...

  5. nGrinder对监控机器收集自定义数据及源码分析

    转载:https://blog.csdn.net/neven7/article/details/50782451 0.背景 性能测试工具nGrinder支持在无需修改源码的情况下,对目标服务器收集自定 ...

  6. (数据挖掘-入门-6)十折交叉验证和K近邻

    主要内容: 1.十折交叉验证 2.混淆矩阵 3.K近邻 4.python实现 一.十折交叉验证 前面提到了数据集分为训练集和测试集,训练集用来训练模型,而测试集用来测试模型的好坏,那么单一的测试是否就 ...

  7. linux可视化桌面安装

    [root@VM_193_201_centos ~]# yum grouplist Loaded plugins: fastestmirror, langpacks There is no insta ...

  8. C#中相关结构的用法及用途

    C#中Dictionary的用法及用途 http://www.cnblogs.com/linzheng/archive/2010/12/13/1904709.html C#中的Dictionary字典 ...

  9. JSP的范围-作用域(web基础学习笔记五)

    JSP的范围(作用域) 在JSP页面中的对象,包括用户创建的对象如JavaBean,都有一个范围属性,这个范围也被叫做“作用域”.范围定义了在什么时间内,在哪一个JSP页面中可以访问这些对象.例如,s ...

  10. 使用FlashPaper 实现JSP在线阅读[转]

    http://cuisuqiang.iteye.com/blog/1841452 使用FlashPaper 实现JSP在线阅读 FlashPaper 是Macromedia推出的一款电子文档类工具,通 ...