乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 将<em>Excel</em>导入到SQL sever数据库,却提示说“外部表...

将<em>Excel</em>导入到SQL sever数据库,却提示说“外部表...

作者:乔山办公网日期:

返回目录:excel表格制作


在asp.net网站中导出Excel文件后,再把文件导入e68a84e8a2ade79fa5e98193362到数据库中。 读取Excel文件时,打开连接出错。
错误为:外部表不是预期的格式
解决:检查了一下,导出的Excel是标准文件不是html,没错,Excel文件正常。
调试代码,创建连接对象oleDbConnection也正常,但在conn.Open()打开链接时出错。
仔细看了下链接字符串,检查出了错误,Excel版本问题,Exce连接字符串版本是office2003的 ,更改为Excel2007版本则正常导入。
using System.Data.OleDb; using System.Data; public void ReadExcelFiless() { //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + Server.MapPath("ExcelFiles/MyExcelFile.xls") + ";Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件 string strConn ="Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Server.MapPath("ExcelFiles/Mydata2007.xlsx") + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串) //备注: "HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反。
// "IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。 OleDbConnection conn= new OleDbConnection(strConn); OleDbDataAdapter adp = new OleDbDataAdapter("Select * from [Sheet1$]", conn); DataSet ds = new DataSet(); adp.Fill(ds, "Book1");this.GridView1.DataSource = ds.Tables["Book1"].DefaultView; this.GridView1.DataBind(); }

你的excel是不是有表头
或者是格式上有合并单元格之类的?
建议把excel表中的数据复制一下,使用只粘贴数据的到一个新表中,导入这个新表试试……
SQL语句中编写的代码针对EXCEL的版本不一样.其实SQL语句似乎只对EXCEL8.0的版本持度比较好.就导入到EXCEL版本上而言.它只是创建一个类似格式,命名为XLS,大部分的EXCEL软件都可以打开.

看看你工程引用的DLL是哪个版本的,再看看你的外部表是哪个版本保存的。版本不一致的话可能会出现这种问题~~

相关阅读

关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网