<!---->
Apache Jakarta POI项目提供了用于访问和生成Excel文档的组件。POI HSSF API用于生成Excel Workbook以及将Excel电子表格添加到workbook。Excel电子表格由行和单元格组成。电子表格的页面布局和字体也使用POI HSSF API进行设置。
通常要求将数据库表呈现在Excel电子表格中。同样,开发人员的需求也可以保存到数据库表中的Excel电子表格中。Apache POI HSSF项目旨在提供一个创建Excel电子表格的API。使用POI HSSF项目生成的Excel电子表格中的数据可以是XML文档中的静态数据,或者是从一个数据库中动态检索到的数据。此外,Excel文档也可以被转换为XML文档或者保存在数据库中。在本教程中,我们将讨论在WebLogic Server中从一个MySQL数据库表创建Excel电子表格的步骤,随后将该Excel电子表格保存在一个数据库表中。
初步设置
org.apache.poi.hssf.usermodel包提供POI HSSF项目的实现。要生成或解析Excel电子表格,需要在类路径中设置org.apache.poi.hssf.usermodel包类。下载Apache POI库poi-bin-2.5.1-final-20040804.zip文件,将该zip文件解压缩所到一个安装目录(http://jakarta.apache.org/poi/)。安装WebLogic Server 8.1。下载MySQL数据库(www.mysql.com)。解压缩MySQL zip文件mysql-4.0.25-win32.zip到一个目录下。安装MySQL数据库。下载MySQL Connector/J JDBC驱动程序(www.mysql.com/products/connector/j/)。解压缩MySQL zip文件mysql-connector-java-3.1.10.zip到一个目录下。添加MySQL JDBC驱动程序jar文件mysql-connector-java-3.1.10-bin.jar到<weblogic81>\samples\domains\examples\startExamplesServer脚本CLASSPATH变量。
使用下面的DOS命令登录到MySQL数据库:
>mysql
使用下面的命令访问示例数据库测试:
mysql>use test
在MySQL数据库中创建一个示例数据库表,将在此生成Excel电子表格。清单1展示了创建示例表Catalog的SQL脚本。
清单1:Catalog.sql
CREATE TABLE Catalog(CatlogId VARCHAR(25)
PRIMARY KEY, Journal VARCHAR(25), Section VARCHAR(25),
Edition VARCHAR(25), Title Varchar(125), Author Varchar(25));
INSERT INTO Catalog VALUES('catalog1', 'dev2dev',
'WebLogic Platform 8.1',
'Oct 2004', 'BEA WebLogic Platform 8.1 SP3 Evaluation Guide',
'dev2dev');
INSERT INTO Catalog VALUES('catalog2', 'dev2dev',
'WebLogic Server',
'Feb 2005', 'Application Architecture for Applications Built on
BEA WebLogic Platform 8.1', 'Bob Hensle');
INSERT INTO Catalog VALUES('catalog3', 'dev2dev',
'WebLogic Integration',
'March 2005', 'The BEA WebLogic Platform and Host Integration',
'Tom Bice');
接下来,我们将向WebLogic Server Classpath添加Apache POI .jar文件,并在WebLogic Server中创建一个JDBC数据源来检索用于Excel电子表格的数据。
添加poi-2.5.1-final-20040804.jar文件到<weblogic81>\samples\domains\examples\startExamplesServer脚本中的CLASSPATH变量中。<weblogic81>是安装WebLogicServices>JDBC>ConnectionServices>JDBC>DataSources节点,并选择Configure a new JDBCTxDataSource。在Configure the data source框中指定数据源名和JNDI名——例如,MySqlDS。在Connect to connection pool框中选择先前使用MySQL数据库配置的连接池。在Target the datasource框中选择examplesServer。这样就使用MySQL数据库配置了一个数据源。
使用Apache POI生成Excel文档
在这一节中,我们将从示例数据库表生成Excel电子表格。首先,创建一个生成Excel电子表格的JSP应用程序。
在JSP中,将从一个MySQL数据库表创建Excel电子表格。使用Apache POI HSSF API来生成Excel电子表格。Apache POI HSSF包中含有用于Excel电子表格的不同组件的类。表1列出了Apache POI HSSF包中一些常用的类:
首先,导入Apache POI HSSF包:
<%@ page import="org.apache.poi.hssf.usermodel.*, java.sql.*,
java.io.*,javax.naming.InitialContext"%>创建一个Excel workbook: