操做Excel导入的问题(转)

当Excel导入成为须要时,以前的导出Excel为html方式的方法就受阻了,因而,须要开始新的百度与google来解决问题。html

前提为OLEDB+Excel。数据库

根据需求,多数是对于表的数据的导入。因而产生这么一个需求过程:网络

1。准备一个空的标准Excel。ide

2。根据表名查询字段this

3。动态生成字段表头google

4。Copy空的标准Excel,循环表头生成新的标准Excel以二进制流导出。spa

5。用户再根据表头的提示添加数据再上传提交。设计

1步和4步为大致上为网上搜出来的想法)excel

过程遇到这么点问题:code

问题1:

网上1步和4步的想法,是先作好标准Excel,直接导出。因此代码上用的insert into table直接往表添加数据了。

于本人的需求有点差距了,异常折腾了半天才折腾到用了Create Table。因而引起了第二个问题:

问题2:

在为Excel Create Table 时,报“不能修改表'xxxx' 的设计。它在只读数据库中”,经本身这么一想,再经网上那么一忽悠。权限问题!。for遍了网络,都直指这个权限问题。

因而就是一堆的往文件夹添加IUser_用户名或EveryOne权限的解决方案,是挺折磨人的,检查了N百遍仍是报的错。

最后在某处看到一条关于数据连接连接的解释以下:

 

代码
若是把Excel看做数据库,那么要注意链接字符串:

private  readonly  string readConn =  " Provider=Microsoft.Jet.OLEDB.4.0; " + " Data Source={0}; "

              + " Extended Properties='Excel 8.0;HDR=YES;IMEX=1;' ";

HDR=YES 表示将sheet的第一行做为列名,因此咱们默认excel的首行是列名。

IMEX= 1 表示大体的意思是使用导入的模式,把数字也做为字符串来操做。


    有一点很重要。IMEX= 1,是一种导入的模式,因此首先这个文件要存在,若是不存在会报错:“Microsoft Jet 数据库引擎找不到对象 ' …\Customer.xls '。请肯定对象是否存在,并正确地写出它的名称和路径”,并且这样写了之后就算文件是存在的,还有一个问题是不能对文件更新的,会提示“不能修改表  ' sheet1 ' 的设计。它在只读数据库中”等错误,甚至还有提示权限的问题。

 

因而去掉IMEX=1,问题解决。

因而问题3也产生了:

新建的表默认都排在最后了,没法排在第一个,这样用户打开看到空的就很差,因而drop table xxx---》无效

忽悠下本身是否是方法不对头,上网搜。因而又发现这么段说明:

 

虽然 Jet OLE DB 提供程序容许您在 Excel 工做簿中插入和更新记录,可是不容许进行 DELETE(删除)操做。若是您尝试对一个或多个记录执行 DELETE 操做,您将收到如下错误信息: 
Deleting data  in a linked table  is not supported by  this ISAM.


这是将 Excel 工做簿做为数据库进行处理时所固有的限制。

 

因而,想了一个比较搜的主意

在空的Excel里删除两个Sheet(默认有三个,系统限制必须存在一个)

而后将剩下的一个更名叫“xxx说明",在里面写操做说明。

 

至此,将就解决,还有不少工做排成队在后面......

相关文章
相关标签/搜索