从前在写读excel文件的程序时,会采用这样的oledb数据连接字符串:
Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\test.xls;Extended Properties='Excel 8.0;HDR=YES;IMEX=0';
但是,在两种情况下,这个oledb的数据连接会出错:一是面对Excel 2007以上的版本的xlsx文件时,二是程序被部署在64位版的操作系统中,而且运行时的程序集被编译为64位或是“任何平台”时。
第一种情况会导致文件打不开,因为jet 4.0不能支持xlsx文件格式。
第二种情况则会在创建ole connection时出现 “Microsoft.Jet.OLEDB.4.0' provider is not registered on the local machine” 的问题。就算是你在64位系统下安装了msdac也不行,msdac里的组件只能被32位模式的程序集访问。
网上有很多人采用强制iis用32位模式运行的方法来解决问题,而且抱怨微软没有提供64位版的msdac组件。但做为重要的office更新,excel 2007版之后不可能不提供数据访问组件的全方面支持。
经过研究才知道,微软已经用新的玩意儿来接了msdac的班,正是因为这个原因,才没有继续在msdac上下功夫,也就没有了jet4.0之后的更新。
新的玩意儿叫Microsoft Access Database Engine, 缩写叫MS ACE, 现在最新版是2010版,这个组件分别发行了32位版与64位版,完整地支持目前所有的excel文件格式,当然还有所有的access文件格式,包括office 2007之前的旧版文件格式,用这个组件里的oledb provider也能一样能打开。
但是,你需要使用新的oledb连接字符串,如下:
Provider=Microsoft.ACE.OLEDB.12.0;Data Source=c:\test.xls;Extended Properties='Excel 12.0;HDR=YES;IMEX=0';
这样的连接字符串可以用于任何office版本的文件格式。而且在windows 64bit上也运行正常。
MS ACE 下载地址在这里: http://www.microsoft.com/en-us/download/details.aspx?id=13255