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

<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

安装SQL Server之后可能

会导致访问邮箱失败

Article last modified on 2002-1-21

--------------------------------------------------------

The information in this article applies to:

  • Microsoft Active Directory Service Interfaces, version 2.5

  • Microsoft Data Access Components version 2.6

--------------------------------------------------------

现象

 

FrontEndServerExchange 2000服务器

从某个时候起,在这台机器上调用微软的CDO或者CDOEX访问Exchange邮箱发生了异常!而且ADSI也工作不正常。

从外表上看,没有任何错误的迹象。

重现步骤如下:

Ø         VB中创建一个应用程序;

Ø         引用CDOEX.DLL;

Ø         代码写入:

         Set oMsg = CreateObject("CDO.Message")

         oMsg.DataSource.Open(“http://BackEndServer/public”)

则在第二行得到这样的错误:

<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />

 

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 SharedCDO

 

原因

首先在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安装包或者补丁。

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

 

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

 

小结

在任何机器上安装SQL Server 2000时,都请注意这个问题!

一旦发现原来可以运行的程序现在爆出一些莫名其妙的错误,请先更新这台机器上的MDAC!打SQL Server 2000 SP1应该也可以,我想。

 

参考文献:

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

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

  <script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
阅读更多
个人分类: 数据库
想对作者说点什么? 我来说一句

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

zgqtxwd zgqtxwd

2008-04-27 18:48:00

阅读数:106

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭