数据库数据用Excel导出的3种方法

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介:

数据库数据用Excel导出的3种方法

分类: .Net    173人阅读  评论(2)  收藏  举报
将数据库数据用Excel导出主要有3种方法:用Excel.Application接口、用OleDB、用HTML的Tabel标签
方法1——Excel.Application接口:
首先,需要要Excel.dll这个文件,确保自身机器上装有MS Office,在Office安装目录(../Microsoft Office/OFFICE11/,具体目录取决于自己的安装)中找到Excel.exe,然后放在(../Microsoft Visual Studio 8/SDK/v2.0/Bin)目录中,在CMD中输入“CD C:/Program Files/Microsoft Visual Studio 8/SDK/v2.0/Bin(具体目录取决于自己的安装)”,然后输入“TlbImp EXCEL.EXE Excel.dll”。然后在Bin这个文件夹中就能找到Excel.dll这个文件。用到时候在项目中引用就可以。
要使用命名空间
   using  Excel;
具体代码:
///   <summary>
///   SQLServer中的数据导出到Excel(使用Excel类,在没装Office时无效)
///   </summary>
///   <param name="ExelDt"> 要导出的数据集 </param>
///   <param name="fileName"> 输出到的文件目录 </param>
public  static void SQLServerToExcel(DataSet ExelDt, string fileName)
{
    int colIndex = 1, rowIndex = 1;
    Excel.Application excel;
    Workbook wBook;
    Worksheet wSheet;
    try
    {
        excel = new Excel.Application();
        wBook = excel.Application.Workbooks.Add(true);
        wSheet = wBook.Worksheets[1] as Worksheet;
        //excel.Visible = true;
    }
    catch
    {
        Win32.MsgBox(0, " 您可能没有安装Office,请安装再使用该功能" "", 0);
        return;
    }
    try
    {
        foreach (DataColumn col in ExelDt.Tables[0].Columns)
        {
            wSheet.Cells[1, colIndex] = col.ColumnName; colIndex++;
        }
        foreach (DataRow row in ExelDt.Tables[0].Rows)
        {
            rowIndex++; colIndex = 0;
            foreach (DataColumn col in ExelDt.Tables[0].Columns)
            {
                colIndex++;
                if (colIndex == 1)
                {
                    wSheet.Cells[rowIndex, colIndex] = "'" + row[col.ColumnName].ToString();
                }
                else
                {
                    wSheet.Cells[rowIndex, colIndex] = row[col.ColumnName].ToString();
                }
            }
        }
        // 设置禁止弹出保存和覆盖的询问提示框
        excel.DisplayAlerts = false;
        excel.AlertBeforeOverwriting = false;
 
        // 保存
        wSheet.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value,
            Missing.Value,Missing.Value, Missing.Value, Missing.Value, Missing.Value);
        wBook.Save();
    }
    catch (System.Exception)
    {
        Win32.MsgBox(0, " 输出Excel有错误,请确认没有关闭Excel" "", 0);
        return;
    }
    finally
    {
        excel.Quit();
    }
}
其中要注意的是:
wSheet.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value,
            Missing.Value,Missing.Value, Missing.Value, Missing.Value, Missing.Value);
wBook.Save();
这样就不会在保存的时候还会弹出保存对话框。
还要记得关闭Excel,不然就一直占有着
finally
{
    excel.Quit();
}
 
方法2——用OleDB:
个人觉得用OleDB最好,因为不需要安装Office也可以导出Excel,而且速度也比较快。
具体代码:
///   <summary>
///   SQLServer中的数据导出到Excel(使用OleDB
///   </summary>
///   <param name="ExelDt"> 要导出的数据集 </param>
///   <param name="filePath"> 输出到的文件目录 </param>
///   <returns> 信息 </returns>
public  static string SQLServerToExcel(System.Data.DataTable ExelDt, string filePath)
{
    if (ExelDt == null)
    {
        return " 数据不能为空" ;
    }
    // 数据集的行总数、列总数
    int rows = ExelDt.Rows.Count;
    int cols = ExelDt.Columns.Count;
    if (rows == 0)
    {
        return " 没有数据" ;
    }
 
    StringBuilder sb = new StringBuilder();
    string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = " + filePath + ";Extended Properties=Excel 8.0";
    OleDbCommand cmd = new OleDbCommand();
    OleDbConnection myConn = new OleDbConnection(strCon);
    try
    {
        // 创建文件
        myConn.Open();
        // 创建表
        cmd.Connection = myConn;
        sb.Append("create table ");
        sb.Append(ExelDt.TableName + "(");
        for (int i = 0; i < cols; i++)
        {
            if (i < cols - 1)
            {
                sb.Append(string.Format("{0} varchar,", ExelDt.Columns[i].ColumnName));
            }
            else
            {
                sb.Append(string.Format("{0} varchar)", ExelDt.Columns[i].ColumnName));
            }
        }
        cmd.CommandText = sb.ToString();
        cmd.ExecuteNonQuery();
    }
    catch (Exception ex)
    {
        return " 建立Exel文件失败:"  + ex.ToString();
    }
 
    //---------------------------------------------------------------------------------
 
    // 插入数据
    sb.Remove(0, sb.Length);
 
    sb.Append("INSERT INTO ");
    sb.Append(ExelDt.TableName + " ( ");
 
    for (int i = 0; i < cols; i++)
    {
        if (i < cols - 1)
            sb.Append(ExelDt.Columns[i].ColumnName + ",");
        else
            sb.Append(ExelDt.Columns[i].ColumnName + ") values (");
    }
 
    for (int i = 0; i < cols; i++)
    {
        if (i < cols - 1)
            sb.Append("@" + ExelDt.Columns[i].ColumnName + ",");
        else
            sb.Append("@" + ExelDt.Columns[i].ColumnName + ")");
    }
    cmd.CommandText = sb.ToString();
    OleDbParameterCollection param = cmd.Parameters;
 
    for (int i = 0; i < cols; i++)
    {
        param.Add(new OleDbParameter("@" + ExelDt.Columns[i].ColumnName, OleDbType.VarChar));
    }
 
     // 遍历DataTable将数据插入新建的Excel文件中
    foreach (DataRow row in ExelDt.Rows)
    {
        for (int i = 0; i < param.Count; i++)
        {
            param[i].Value = row[i];
        }
 
        cmd.ExecuteNonQuery();
    }
 
    cmd.Connection.Close();
 
    return " 数据已成功导入Excel" ;
}
其中注意:
string  strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = " + filePath + ";Extended Properties=Excel 8.0";
其中“Excel 8.0”是表示使用MS Office 2003,其他版本的没有用过,不确定是否只需修改版本号就可以。
 
方法3——用HTML的Tabel标签:
这个具体我没试过实现,这里给个思路,将要导出的数据用<tabel>、<tr>、<td>这几个标签输出成HTML文件,然后把扩展名改为.xls就可以。

本文转自9pc9com博客,原文链接:     http://blog.51cto.com/215363/744257    如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
431 10
|
2月前
|
数据采集 数据库 Python
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
169 75
|
1月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
109 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
15天前
|
关系型数据库 数据库连接 数据库
循序渐进丨MogDB 中 gs_dump 数据库导出工具源码概览
通过这种循序渐进的方式,您可以深入理解 `gs_dump` 的实现,并根据需要进行定制和优化。这不仅有助于提升数据库管理的效率,还能为数据迁移和备份提供可靠的保障。
33 6
|
18天前
|
分布式计算 Hadoop 大数据
从Excel到Hadoop:数据规模的进化之路
从Excel到Hadoop:数据规模的进化之路
45 10
|
16天前
|
数据库
【YashanDB 知识库】数据库一主一备部署及一主两备部署时,主备手动切换方法及自动切换配置
**数据库主备切换简介** 在数据库正常或异常情况下,实现主备切换至关重要。若配置不当,主节点故障将影响业务使用,尤其在23.2版本中。原因包括资源紧张或主节点异常。解决方法涵盖手动和自动切换: 1. **一主一备部署**: - **手动切换**:支持Switchover(同步正常时)和Failover(主库损坏时)。 - **自动切换**:启用yasom仲裁选主开关。 2. **一主两备部署**: - 默认最大保护模式,自动切换开启。 需检查并配置自动切换以确保高可用性。经验总结:一主一备默认关闭自动切换,需手动开启;一主两备默认开启。
|
1月前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
131 8
|
14天前
|
数据库 数据安全/隐私保护
【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`。
|
3月前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
165 8
|
3月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。

热门文章

最新文章