一、现象
我的这台机器上调用微软的CDO或者CDOEX访问Exchange邮箱发生了异常!而且ADSI也工作不正常。从外表上看,没有任何错误的迹象。
重现步骤如下:
VB中创建一个应用程序;
引用CDOEX.DLL;
代码写入:
Set oMsg = createObject(“CDO.Message”)
oMsg.DataSource.Open(“http://BackEndServer/public”)
则在第二行得到这样的错误:
Run-time error ‘-2147221164(80040154)’:
无法向注册表写入项
FrontEndServer 配置:
Windows Advanced Server 2000 内部版本号 2195:Service Pack 2
IE 版本:5.00.3315.1000 更新版本:SP2
CDOEX.DLL的版本号:6.0.4417.0
它所处的位置:C:Program FilesCommon FilesMicrosoft
二、原因
首先在FrontEndServer 安装了SQL Server 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之后,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 2000之后,请一定要下载最新的MDAC安装包或者补丁。
解决这个CDOEX的问题,就是下载并安装MDAC 2.6 SP1 (2.61.7326.6).exe。
三、小结
在任何机器上安装SQL Server 2000时,都请注意这个问题!
一旦发现原来可以运行的程序现在爆出一些莫名其妙的错误,请先更新这台机器上的MDAC或者打SQL Server 2000 SP1。
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
作者
相关推荐
-
SQL Server 2012 RTM 安装手记
2012年3月7日,微软终于如约发布了内部版本号为11.0.2100.60的新一代数据库平台:SQL Server 2012。
-
分析SQL Server级联删除的实现
SQL Server 2000与Oracle 8i相比,SQL Server级联删除有太多的限制,本文就为您介绍SQLServer级联删除的实现方法,供您参考。
-
从SQL Server中的数据更新到Oracle表中
我有两个客户端服务程序。一个用的是Oracle7数据库,而另一个用的是SQL Server 2000。现在我想把SQL Server 2000中的某些表数据更新到Oracle数据库表中……
-
在SQL Server 2000的视图中小心使用*符号(一)
有些朋友看到这个标题可能会有疑问,难道在视图中使用*符号还有何要注意的地方吗?对于这个问题,我们先不必回答,先看一下文中的例子吧。