zoukankan      html  css  js  c++  java
  • 数据库导出为Excel

    创建数据库和表:

    create database test;
    crate table test(
      id int primary key,
      name varchar(10),
      sex varchar(10),
      age int,
      address varchar(20)
    );

    插入测试数据:

    insert into test values(1,'zhangsan1','男',20,'北京');
    insert into test values(2,'zhangsan2','女',22,'北京');
    insert into test values(3,'zhangsan3','女',20,'北京');
    insert into test values(4,'zhangsan4','男',18,'北京');
    insert into test values(5,'zhangsan5','男',20,'北京');

    Servlet: JavaToExcel.java

    import java.io.IOException;
    import java.io.OutputStream;
    import java.io.OutputStreamWriter;
    import java.io.PrintWriter;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import java.util.Hashtable;
    import java.util.List;
    import java.util.Vector;
    
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import jxl.Workbook;
    import jxl.format.Alignment;
    import jxl.format.VerticalAlignment;
    import jxl.write.Label;
    import jxl.write.WritableCellFormat;
    import jxl.write.WritableFont;
    import jxl.write.WritableSheet;
    import jxl.write.WritableWorkbook;
    import jxl.write.WriteException;
    
    public class JavaToExcel extends HttpServlet {
    
    	public void doGet(HttpServletRequest request, HttpServletResponse response)
    			throws ServletException, IOException {
    
    		//数据库操作 
    		try {
    			Class.forName("com.mysql.jdbc.Driver");
    		} catch (ClassNotFoundException e1) {
    			// TODO Auto-generated catch block
    			e1.printStackTrace();
    		}
    		Connection con = null;
    		PreparedStatement pst = null;
    		ResultSet rs = null;
    		int rows = 1;
    		try {
    			 con = DriverManager.getConnection("jdbc:mysql://localhost:3306/test","root","123");
    		     pst = con.prepareStatement("select * from test");
    		     rs = pst.executeQuery();
    		} catch (SQLException e1) {
    			// TODO Auto-generated catch block
    			e1.printStackTrace();
    		}
    		
    		
    		//标题 
    		String fileName = "my first execl";
    		// 获得 OutputStream 最后把生成的excel通过这个写出
    	   	OutputStream os = response.getOutputStream();
    	
    		 response.setContentType("application/ms-excel;charset=gbk");
    		 request.setCharacterEncoding("gbk");
    		 response.setContentType("text/html;charset=gbk");
    		 
    		// 设置头
    		response.setHeader("Content-Disposition", "attachment;filename="+ fileName + ".xls");
    
    		
    		// 标题字体  WritableFont(FontName fn,int ps,BoldStyle bs,Boolean italic) 字体类型  字体大小 字体样式  是否斜体
    		WritableFont wfc = new WritableFont(WritableFont.ARIAL, 15, WritableFont.BOLD, true);
    		WritableCellFormat wcfFC = new WritableCellFormat(wfc);
    
    		// 标题 居中对齐
    		try {
    			//左右居中
    			wcfFC.setAlignment(Alignment.CENTRE);
    			//上下居中 
    			wcfFC.setVerticalAlignment(VerticalAlignment.CENTRE);
    		} catch (WriteException e) {
    			e.printStackTrace();
    		}
    		try {
    			// 字段字体
    			WritableFont wfc1 = new WritableFont(WritableFont.COURIER, 10, WritableFont.BOLD, true);
    			WritableCellFormat wcfFC1 = new WritableCellFormat(wfc1);
    			wcfFC1.setAlignment(Alignment.CENTRE); //左右居中 
    			wcfFC1.setVerticalAlignment(VerticalAlignment.CENTRE);  //上下居中 
    
    			// 通过OutputStream对象os创建Workbook
    			WritableWorkbook wbook = Workbook.createWorkbook(os);
    			// 创建sheet
    			WritableSheet wsheet = wbook.createSheet("sheet", 0);
    
    			// 加入标题
    			wsheet.mergeCells(0, 0, 6, 0); //第一行合并7个单元格  
    			wsheet.addCell(new Label(0, 0, "人员信息表", wcfFC));// 写标题 看出坐标是基于 0,0
    			
    			try{
    				while(rs.next()){
    						wsheet.addCell(new Label(0,rows,rs.getString(1),wcfFC1));  //列,行 
    						wsheet.addCell(new Label(1,rows,rs.getString(2),wcfFC1));
    						wsheet.addCell(new Label(2,rows,rs.getString(3),wcfFC1));
    						wsheet.addCell(new Label(3,rows,rs.getString(4),wcfFC1));
    						wsheet.addCell(new Label(4,rows,rs.getString(5),wcfFC1));
    						rows++;
    				}
    			}catch(Exception e){
    				
    			}
    
    			// 加入打印时间
    			 Date aaa = new Date();
    			 SimpleDateFormat aSimpleDateFormat = new
    			 java.text.SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    			 String today = aSimpleDateFormat.format(aaa);
    			 wsheet.addCell(new Label(5, rows+1, "打印日期:"));
    			 wsheet.addCell(new Label(6, rows+1, today));
    		
    			// 写入流中
    			wbook.write();
    			wbook.close();
    			os.close();
    		} catch (WriteException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}	
    	}
    	public void doPost(HttpServletRequest request, HttpServletResponse response)
    			throws ServletException, IOException {
    		this.doGet(request, response);
    	}
    
    }
    

    前台jsp页面 只需一个超链接<a>测试

    <a href="javaToExcel">导出Excel</a>  <!-- javaToExcel 为我的servlet URL映射路径  在web.xml里面配置有 -->
    
    
    注:所需jar包  jxl.jar  mysql.jar驱动

    如果报java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/test 错误

    可能原因有 mysql驱动必须放在 lib目录下。而不能右键项目 Build Path-->Add External... 

  • 相关阅读:
    雅米新一代企业管理平台
    Telerik.Web.UI应用到sharepoint2010注意事项
    SharePoint Server 2010 容量管理:软件边界和限制
    【读】构建可枚举类型(IEnumerator和IEnumerable)
    【读】C# 窗口间传递数据
    分类(转)
    “盗”亦有道
    English学习指南
    爱情是什么?
    客户需要的26个待遇 (转)
  • 原文地址:https://www.cnblogs.com/itmyhome/p/4131600.html
Copyright © 2011-2022 走看看