Excel导入到数据库(二)

2024-06-08 20:08
文章标签 excel 数据库 导入到

本文主要是介绍Excel导入到数据库(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        之前就写过一个将excel导入数据库的博客,http://blog.csdn.net/u011458469/article/details/41913293。这个是利用的Office的一个接口,直接就导入了。但是这个方法有很大的局限性,要求本地得有Office并且还要求了位数是64还是32位,不同位的Office提供了不同的接口,所以这个方法就对环境有了很大的要求,并且这个方法性能不怎么好,导入个1000条的数据就得停顿个2、3秒的。本文介绍了另外一种方法:利用Aspose.cells来导入。(该控件是商用的)

        首先,就是引用该控件:


然后导入命名空间:using Aspose.Cells;

第一步是将excel导入到DataTable中:

 //读取excel的数据,并放到datatable中。public static System.Data.DataTable ReadExcel(string filePath){Workbook book = new Workbook();book.Open(filePath);Worksheet sheet = book.Worksheets[0];Cells cells = sheet.Cells;return cells.ExportDataTableAsString(0, 0, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, true);}
参数是要导入的excel表的路径。

导入到datatable中之后,第二步就是将该datatable添加到数据库的表中(要添加的表是新建的表,并且表的字段也是变量):

public void Import(string dataTableName, string filePath){//获取excel的数据,放到dt中DataTable dt = ReadExcel(filePath);//获取dt的所有字段名,放入strFieldsName中List<string> strFieldsName = new List<string>();foreach (DataColumn dc in dt.Columns){strFieldsName.Add(dc.ColumnName);}//定义list,拼接字符串List<string> list = new List<string>();string fName = null;for (int i = 0; i < dt.Columns.Count; i++){string fieldsName = strFieldsName[i].ToString().Trim();  //字段名list.Add(fieldsName);fName += list[i].ToString().Trim() + " varchar(30),";//获取字段名,并拼接字符串}fName = fName.Substring(0, fName.Length - 1);//去掉循环到最后的逗号","string sqlStr = "create table " + dataTableName + "( " + fName + ")";string strConn = ConfigurationManager.ConnectionStrings["sqlConn"].ConnectionString;//获取连接数据库的字符串//实例化sql连接SqlConnection conn = new SqlConnection(strConn);conn.Open();//实例化sql命令SqlCommand cmd = new SqlCommand(sqlStr, conn);//执行sql命令,创建数据表。cmd.ExecuteNonQuery();//关闭连接conn.Close();//将dt的数据放到新建的数据表中SqlBulkCopy sqlbulkcopy = new SqlBulkCopy(strConn, SqlBulkCopyOptions.UseInternalTransaction);sqlbulkcopy.DestinationTableName = dataTableName;//数据库中的表名sqlbulkcopy.WriteToServer(dt);}
参数是要新建的表名(tableName)和文件路径(filePath)。

这样就可以导入数据库中了。



这篇关于Excel导入到数据库(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043185

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

C#利用Free Spire.XLS for .NET复制Excel工作表

《C#利用FreeSpire.XLSfor.NET复制Excel工作表》在日常的.NET开发中,我们经常需要操作Excel文件,本文将详细介绍C#如何使用FreeSpire.XLSfor.NET... 目录1. 环境准备2. 核心功能3. android示例代码3.1 在同一工作簿内复制工作表3.2 在不同

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方

MySQL批量替换数据库字符集的实用方法(附详细代码)

《MySQL批量替换数据库字符集的实用方法(附详细代码)》当需要修改数据库编码和字符集时,通常需要对其下属的所有表及表中所有字段进行修改,下面:本文主要介绍MySQL批量替换数据库字符集的实用方法... 目录前言为什么要批量修改字符集?整体脚本脚本逻辑解析1. 设置目标参数2. 生成修改表默认字符集的语句3

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一

Java利用Spire.XLS for Java设置Excel表格边框

《Java利用Spire.XLSforJava设置Excel表格边框》在日常的业务报表和数据处理中,Excel表格的美观性和可读性至关重要,本文将深入探讨如何利用Spire.XLSforJava库... 目录Spire.XLS for Java 简介与安装Maven 依赖配置手动安装 JAR 包核心API介