haoxiaobo

从C到C++又到.net, 有一些心得, 和大家交流下...
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

谁是DAC2.8和jet4.0的接班人?

Posted on 2013-01-14 21:45  HAL9000  阅读(649)  评论(0编辑  收藏  举报

从前在写读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