使用NPOI导出数据库到Excel文件

简介: 教程地址:http://www.cnblogs.com/atao/category/209358.html NPOI文件包:http://u.115.com/file/aqr5pjb7 程序源码:http://u.

教程地址:http://www.cnblogs.com/atao/category/209358.html

NPOI文件包:http://u.115.com/file/aqr5pjb7

程序源码:http://u.115.com/file/bhvr12dq

 

代码中数据库链接字符串自己修改,还有对应的字段名之类的信息;

新建一个Handler.ashx(一般处理程序) 代码如下:

 

using  System;
using  System.Collections.Generic;
using  System.Linq;
using  System.Web;
using  System.Data;
using  System.Data.SqlClient;
using  NPOI.HSSF.UserModel;


namespace  ExportToExcelWeb
{
    
///   <summary>
    
///  ExportToExcel 的摘要说明
    
///   </summary>
     public   class  ExportToExcel : IHttpHandler
    {

        
public   void  ProcessRequest(HttpContext context)
        {
            context.Response.ContentType 
=   " application/x-excel " ;
            
string  fileName  =  HttpUtility.UrlEncode( " 数据库文备份.xls " );
            context.Response.AddHeader(
" Content-Disposition " " attachment; fileName= "   +  fileName);   // 添加http协议报文;

            HSSFWorkbook workbook 
=   new  HSSFWorkbook();  // 创建一个xls;
            HSSFSheet sheet  =  workbook.CreateSheet();  // 创建一个Sheet页

            
string  connectString  =   @" server=localhost\sql2008;database=MyBlog; uid=sa; pwd=sql2008 " ;
            SqlConnection connection 
=   new  SqlConnection(connectString);
            connection.Open();

            
using  (IDbCommand cmd  =  connection.CreateCommand())  // 接口编徎;
            {
                cmd.CommandText 
=   " select * from Users " ;
                
using  (IDataReader reader  =  cmd.ExecuteReader())
                {
                    
int  rowsNum  =   0 ;   // 行号
                     while  (reader.Read())
                    {
                        
// 根据字段名找出ID
                         string  LoginId  =  reader.GetString(reader.GetOrdinal( " LoginId " ));
                        
string  LoginPwd  =  reader.GetString(reader.GetOrdinal( " LoginPwd " ));
                        
string  Name  =  reader.GetString(reader.GetOrdinal( " Name " ));
                        
string  QQ  =  reader.GetString(reader.GetOrdinal( " QQ " ));
                        
string  Mail  =  reader.GetString(reader.GetOrdinal( " Mail " ));

                        
/* *****************以上代码对应数据库表中的字段******************** */

                        HSSFRow row 
=  sheet.CreateRow(rowsNum);
                        row.CreateCell(
0 , HSSFCell.CELL_TYPE_STRING).SetCellValue(LoginId);
                        row.CreateCell(
1 , HSSFCell.CELL_TYPE_STRING).SetCellValue(LoginPwd);
                        row.CreateCell(
2 , HSSFCell.CELL_TYPE_STRING).SetCellValue(Name);
                        row.CreateCell(
3 , HSSFCell.CELL_TYPE_STRING).SetCellValue(QQ);
                        row.CreateCell(
4 , HSSFCell.CELL_TYPE_STRING).SetCellValue(Mail);

                        
/* *****************以上代码对应Excel文件的列*********************** */
                        rowsNum
++ ;
                    }
                }
            }

            workbook.Write(context.Response.OutputStream);  
// 输出到流中

        }

        
public   bool  IsReusable
        {
            
get
            {
                
return   false ;
            }
        }
    }
}

 

Aspx页面代码:

 

<% @ Page Language = " C# "  AutoEventWireup = " true "  CodeBehind = " Default.aspx.cs "  Inherits = " ExportToExcelWeb.Default "   %>

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >

< html  xmlns ="http://www.w3.org/1999/xhtml" >
< head  runat ="server" >
    
< title ></ title >
</ head >
< body >
    
< form  id ="form1"  runat ="server" >
    
< div >
    
< href ="ExportToExcel.ashx" > 下载备份数据库文件到Excel格式 </ a >
    
</ div >
    
</ form >
</ body >
</ html >

 

目录
相关文章
|
4月前
|
SQL 关系型数据库 MySQL
如何将Excel表的数据导入RDS MySQL数据库?
本文介绍如何通过数据管理服务DMS将Excel文件(转为CSV格式)导入RDS MySQL数据库,涵盖建表、编码设置、导入模式选择及审批执行流程,并提供操作示例与注意事项。
|
6月前
|
Python
Excel中如何批量重命名工作表与将每个工作表导出到单独Excel文件
本文介绍了如何在Excel中使用VBA批量重命名工作表、根据单元格内容修改颜色,以及将工作表导出为独立文件的方法。同时提供了Python实现导出工作表的代码示例,适用于自动化处理Excel文档。
|
7月前
|
Java 测试技术 数据库
spring号码归属地批量查询,批量查询号码归属地,在线工具,可按省份城市运营商号段分类分开分别导出excel表格
简介:文章探讨Spring Boot项目启动优化策略,通过自定义监听器、异步初始化及分库分表加载优化等手段,将项目启动时间从280秒缩短至159秒,提升约50%,显著提高开发效率。
|
10月前
|
数据库 数据安全/隐私保护
【YashanDB知识库】exp 导出数据库时,报错YAS-00402
【YashanDB知识库】exp 导出数据库时,报错YAS-00402
【YashanDB知识库】exp 导出数据库时,报错YAS-00402
|
11月前
|
关系型数据库 数据库连接 数据库
循序渐进丨MogDB 中 gs_dump 数据库导出工具源码概览
通过这种循序渐进的方式,您可以深入理解 `gs_dump` 的实现,并根据需要进行定制和优化。这不仅有助于提升数据库管理的效率,还能为数据迁移和备份提供可靠的保障。
326 6
|
11月前
|
数据库 数据安全/隐私保护
【YashanDB 知识库】exp 导出数据库时,报错 YAS-00402
**简介:** 在执行数据导出命令 `exp --csv -f csv -u sales -p sales -T area -O sales` 时,出现 YAS-00402 错误,提示“Connection refused”。原因是数据库安装时定义的 IP 地址或未正确配置导致连接失败。解决方法是添加 `--server-host ip:port` 参数,例如 `exp --csv -f csv -u sales -p sales -T area -O sales --server-host 192.168.33.167:1688`。
|
4月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
183 3
|
4月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
4月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
883 152
|
4月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。