导出数据库数据到Excel

本文介绍了一个使用Apache POI从数据库导出数据到Excel文件的示例。该示例包括创建Web工程、导入必要的jar包、编写获取数据库数据的类、生成Excel文件的Servlet以及打开Excel文件的Servlet。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

做了一个利用POI导出数据库数据到Excel的例子,并把这个例子与大家一起分享,一起学习,共同进步!
先简单介绍一下poi,poi是apache组织的一个开源项目,最新版为poi-3.0.1,要使用poi需要到apache网站下载poi-bin3.0.1.zip压缩包,并将poi-3.0.1.jar加入到项目的ClassPath中。

下面是完成这个实例的步骤:

1、建立好一个web工程:poi;

2、导入所需要的jar包:poi-3.0.1.jar和mysql数据库驱动包;

3、编写一个StudentResultSet类,用于取出数据库中的数据;

Java代码 复制代码
  1. packageorg.hnylj.poi;
  2. importjava.sql.Connection;
  3. importjava.sql.DriverManager;
  4. importjava.sql.PreparedStatement;
  5. importjava.sql.ResultSet;
  6. importjava.sql.SQLException;
  7. publicclassStudentResultSet{
  8. privateConnectionconn;
  9. privatePreparedStatementpstmt;
  10. privateResultSetrs;
  11. privatestaticfinalStringDRIVER="com.mysql.jdbc.Driver";
  12. privatestaticfinalStringURL="jdbc:mysql://localhost:3306/poi";
  13. privatestaticfinalStringUSERNAME="root";
  14. privatestaticfinalStringPASSWORD="123";
  15. //查询数据库中的数据
  16. publicResultSetquery(){
  17. try{
  18. Class.forName(DRIVER);
  19. conn=DriverManager.getConnection(URL,USERNAME,PASSWORD);
  20. pstmt=conn.prepareStatement("select*fromstudent");
  21. rs=pstmt.executeQuery();
  22. }catch(ClassNotFoundExceptione){
  23. e.printStackTrace();
  24. }catch(SQLExceptione){
  25. e.printStackTrace();
  26. }
  27. returnrs;
  28. }
  29. }
package org.hnylj.poi;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class StudentResultSet {
	private Connection conn;
	private PreparedStatement pstmt;
	private ResultSet rs;
	private static final String DRIVER = "com.mysql.jdbc.Driver";
	private static final String URL = "jdbc:mysql://localhost:3306/poi";
	private static final String USERNAME = "root";
	private static final String PASSWORD = "123";
    
	//查询数据库中的数据
	public ResultSet query() {
		try {
			Class.forName(DRIVER);
			conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
			pstmt = conn.prepareStatement("select * from student");
			rs = pstmt.executeQuery();
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return rs;
	}
}

4、编写一个BuildExcelServlet,用于生成Excel;

Java代码 复制代码
  1. packageorg.hnylj.poi;
  2. importjava.io.FileOutputStream;
  3. importjava.io.IOException;
  4. importjava.sql.ResultSet;
  5. importjava.sql.ResultSetMetaData;
  6. importjavax.servlet.ServletException;
  7. importjavax.servlet.http.HttpServlet;
  8. importjavax.servlet.http.HttpServletRequest;
  9. importjavax.servlet.http.HttpServletResponse;
  10. importorg.apache.poi.hssf.usermodel.HSSFCell;
  11. importorg.apache.poi.hssf.usermodel.HSSFRichTextString;
  12. importorg.apache.poi.hssf.usermodel.HSSFRow;
  13. importorg.apache.poi.hssf.usermodel.HSSFSheet;
  14. importorg.apache.poi.hssf.usermodel.HSSFWorkbook;
  15. publicclassBuildExcelServletextendsHttpServlet{
  16. protectedvoiddoGet(HttpServletRequestrequest,
  17. HttpServletResponseresponse)throwsServletException,IOException{
  18. StudentResultSetstuResultSet=newStudentResultSet();
  19. ResultSetrs=stuResultSet.query();
  20. StringxlsName="test.xls";
  21. StringsheetName="sheetName";
  22. HSSFWorkbookworkbook=newHSSFWorkbook();
  23. HSSFSheetsheet=workbook.createSheet();
  24. workbook.setSheetName(0,sheetName);
  25. HSSFRowrow=sheet.createRow((short)0);
  26. HSSFCellcell;
  27. try{
  28. ResultSetMetaDatamd=rs.getMetaData();
  29. intnColumn=md.getColumnCount();
  30. for(inti=1;i<=nColumn;i++){
  31. cell=row.createCell((short)(i-1));
  32. cell.setCellType(HSSFCell.CELL_TYPE_STRING);
  33. cell.setCellValue(newHSSFRichTextString(md.getColumnLabel(i)));
  34. }
  35. intiRow=1;
  36. while(rs.next()){
  37. row=sheet.createRow((short)iRow);
  38. ;
  39. for(intj=1;j<=nColumn;j++){
  40. cell=row.createCell((short)(j-1));
  41. cell.setCellType(HSSFCell.CELL_TYPE_STRING);
  42. cell.setCellValue(newHSSFRichTextString(rs.getObject(j)
  43. .toString()));
  44. }
  45. iRow++;
  46. }
  47. Stringfilename=request.getRealPath("/")+xlsName;
  48. request.setAttribute("filename",filename);
  49. FileOutputStreamfOut=newFileOutputStream(filename);
  50. workbook.write(fOut);
  51. fOut.flush();
  52. fOut.close();
  53. request.getRequestDispatcher("OpenExcelServlet").forward(request,
  54. response);
  55. }catch(Exceptione){
  56. e.printStackTrace();
  57. }
  58. }
  59. protectedvoiddoPost(HttpServletRequestrequest,
  60. HttpServletResponseresponse)throwsServletException,IOException{
  61. this.doGet(request,response);
  62. }
  63. }
package org.hnylj.poi;

import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class BuildExcelServlet extends HttpServlet {

	protected void doGet(HttpServletRequest request,
			HttpServletResponse response) throws ServletException, IOException {
		StudentResultSet stuResultSet = new StudentResultSet();
		ResultSet rs = stuResultSet.query();
		String xlsName = "test.xls";
		String sheetName = "sheetName";

		HSSFWorkbook workbook = new HSSFWorkbook();
		HSSFSheet sheet = workbook.createSheet();
		workbook.setSheetName(0, sheetName);
		HSSFRow row = sheet.createRow((short) 0);
		HSSFCell cell;
		try {
			ResultSetMetaData md = rs.getMetaData();
			int nColumn = md.getColumnCount();

			for (int i = 1; i <= nColumn; i++) {
				cell = row.createCell((short) (i - 1));
				cell.setCellType(HSSFCell.CELL_TYPE_STRING);
				cell.setCellValue(new HSSFRichTextString(md.getColumnLabel(i)));
			}
			int iRow = 1;
			while (rs.next()) {
				row = sheet.createRow((short) iRow);
				;
				for (int j = 1; j <= nColumn; j++) {
					cell = row.createCell((short) (j - 1));
					cell.setCellType(HSSFCell.CELL_TYPE_STRING);
					cell.setCellValue(new HSSFRichTextString(rs.getObject(j)
							.toString()));
				}
				iRow++;
			}
			String filename = request.getRealPath("/") + xlsName;
			request.setAttribute("filename", filename);
			FileOutputStream fOut = new FileOutputStream(filename);
			workbook.write(fOut);
			fOut.flush();
			fOut.close();
			request.getRequestDispatcher("OpenExcelServlet").forward(request,
					response);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	protected void doPost(HttpServletRequest request,
			HttpServletResponse response) throws ServletException, IOException {
		this.doGet(request, response);
	}
}

5、编写一个OpenExcelServlet,用于把生成的Excel在页面上打开;

Java代码 复制代码
  1. packageorg.hnylj.poi;
  2. importjava.io.BufferedInputStream;
  3. importjava.io.FileInputStream;
  4. importjava.io.IOException;
  5. importjava.io.PrintWriter;
  6. importjavax.servlet.ServletException;
  7. importjavax.servlet.http.HttpServlet;
  8. importjavax.servlet.http.HttpServletRequest;
  9. importjavax.servlet.http.HttpServletResponse;
  10. publicclassOpenExcelServletextendsHttpServlet{
  11. publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)
  12. throwsServletException,IOException{
  13. response.setContentType("application/vnd.ms-excel");
  14. PrintWriterout=response.getWriter();
  15. StringfilePath=(String)request.getAttribute("filename");
  16. BufferedInputStreambis=null;
  17. try{
  18. bis=newBufferedInputStream(newFileInputStream(filePath));
  19. intbytesRead;
  20. while((bytesRead=bis.read())!=-1){
  21. out.write(bytesRead);
  22. out.flush();
  23. }
  24. }catch(IOExceptione){
  25. e.printStackTrace();
  26. }finally{
  27. if(bis!=null)
  28. bis.close();
  29. if(out!=null)
  30. out.close();
  31. }
  32. }
  33. publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)
  34. throwsServletException,IOException{
  35. this.doGet(request,response);
  36. }
  37. }
package org.hnylj.poi;

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class OpenExcelServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("application/vnd.ms-excel");
		PrintWriter out = response.getWriter();
		String filePath = (String) request.getAttribute("filename");
		BufferedInputStream bis = null;
		try {
			bis = new BufferedInputStream(new FileInputStream(filePath));
			int bytesRead;
			while ((bytesRead = bis.read()) != -1) {
				out.write(bytesRead);
				out.flush();
			}
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			if (bis != null)
				bis.close();
			if (out != null)
				out.close();
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		this.doGet(request, response);
	}
}

6、在web.xml里配置一下servlet的映射;

Xml代码 复制代码
  1. <servlet>
  2. <servlet-name>BuildExcelServlet</servlet-name>
  3. <servlet-class>org.hnylj.poi.BuildExcelServlet</servlet-class>
  4. </servlet>
  5. <servlet>
  6. <servlet-name>OpenExcelServlet</servlet-name>
  7. <servlet-class>org.hnylj.poi.OpenExcelServlet</servlet-class>
  8. </servlet>
  9. <servlet-mapping>
  10. <servlet-name>OpenExcelServlet</servlet-name>
  11. <url-pattern>/OpenExcelServlet</url-pattern>
  12. </servlet-mapping>
  13. <servlet-mapping>
  14. <servlet-name>BuildExcelServlet</servlet-name>
  15. <url-pattern>/BuildExcelServlet</url-pattern>
  16. </servlet-mapping>
        <servlet>
		<servlet-name>BuildExcelServlet</servlet-name>
		<servlet-class>org.hnylj.poi.BuildExcelServlet</servlet-class>
	</servlet>
	<servlet>
		<servlet-name>OpenExcelServlet</servlet-name>
		<servlet-class>org.hnylj.poi.OpenExcelServlet</servlet-class>
	</servlet>

	<servlet-mapping>
		<servlet-name>OpenExcelServlet</servlet-name>
		<url-pattern>/OpenExcelServlet</url-pattern>
	</servlet-mapping>

	<servlet-mapping>
		<servlet-name>BuildExcelServlet</servlet-name>
		<url-pattern>/BuildExcelServlet</url-pattern>
	</servlet-mapping>

7、启动tomcat,运行程序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值