WEB开发网
开发学院数据库MSSQL Server 安装SQLServer2K可能引发一个严重问题 阅读

安装SQLServer2K可能引发一个严重问题

 2007-11-11 07:17:28 来源:WEB开发网   
核心提示: 原因 首先在FrontEndServer 安装了sql server(WINDOWS平台上强大的数据库平台) 2000之前,我们可以使用CDOEX的IDataSource.Open打开用户邮箱的:_ConnectionPtr pCon = NULL; CComPtr <CDO::IFolder>pFldr

原因

首先在FrontEndServer 安装了sql server(WINDOWS平台上强大的数据库平台) 2000之前,我们可以使用CDOEX的IDataSource.Open打开用户邮箱的:

_ConnectionPtr pCon = NULL;

CComPtr <CDO::IFolder>pFldr;

CComPtr <CDO::IDataSource>pSource;

hr=pFldr.CoCreateInstance(L"CDO.Folder");

pFldr->get_DataSource(&pSource);

hr=pSource->Open(bstrURLInbox,

                   (IDispatch*)pCon,

                  adModeRead,

                       adFailIfNotExists,

                       adOpenSource,

                       bstrUserDomainAccount,

                       bstrUserPwd);

 

但是安装了sql server(WINDOWS平台上强大的数据库平台)之后,MDAC就被更新到了version 2.6!!

 

由于Microsoft的过错,早期的一些MDAC组件被MDAC 2.6删除或者被覆盖掉了!!

 

而运行IDataSource.Open,是需要引用MDAC 2.5的这些被删除了的组件的,所以就会报出“Class Not Registered”的错误。

 

此时,如果运行下面的代码:

   Set con = CreateObject("ADODB.Connection")
   con.Provider = "ADsDSOObject"
   con.Open "ADs Provider"

最后一行会失败并报错:run-tim error 429 'ActiveX component can't create object'

这种情况被新闻组的人们称之为“ADSI toasting ADO”!!

 

这就是一个非常严重的问题了。你的要使用到以前的ADO的接口的程序可能都不行了!

 

所以,安装了sql server(WINDOWS平台上强大的数据库平台) 2000之后,请一定从下列站点下载最新的MDAC安装包或者补丁。

http://www.microsoft.com/data/download_26sp1.htm

 

解决这个CDOEX的问题,就是下载并安装了MDAC 2.6 SP1 (2.61.7326.6).exe就可以了。

 

小结

在任何机器上安装sql server(WINDOWS平台上强大的数据库平台) 2000时,都请注意这个问题!

一旦发现原来可以运行的程序现在爆出一些莫名其妙的错误,请先更新这台机器上的MDAC!打sql server(WINDOWS平台上强大的数据库平台) 2000 SP1应该也可以,我想。

 

参考文献:

1.  《PRB: ADSI 2.5 and MDAC 2.6 Compatibility Issues (Q275917)》

2.  《INFO: Determining Which Version of ADSI Is Installed (Q216290)》

上一页  1 2 

Tags:安装 SQLServerK 可能

编辑录入:coldstar [复制链接] [打 印]
赞助商链接