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

系统 1756 0

 

安装 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

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

现象

 

FrontEndServer Exchange 2000服务器

从某个时候起,在这台机器上调用微软的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 Files\Common Files\Microsoft Shared\CDO

 

原因

首先在 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)

 



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=12660


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


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论