加载中...
查看文章
  • 安装SQL Server 2000 可能引发一个严重问题
  • 作者:未知 来源:未知 添加时间:2006年7月3日 字体:
  • 84642安装SQL Server之后可能
    I-_G1Sl

    会导致访问邮箱失败


    I-_G1Sl

    Article last modified on 2002-1-21


    I-_G1Sl

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


    I-_G1Sl

    The information in this article applies to:


    I-_G1Sl

      I-_G1Sl
    • Microsoft Active Directory Service Interfaces, version 2.5

    I-_G1Sl

      I-_G1Sl
    • Microsoft Data Access Components version 2.6

    I-_G1Sl

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


    I-_G1Sl

    现象


    I-_G1Sl

     


    I-_G1Sl

    FrontEndServer是Exchange 2000服务器;


    I-_G1Sl

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


    I-_G1Sl

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


    I-_G1Sl

    重现步骤如下:

    ?         VB中创建一个应用程序;
    
    I-_G1Sl
    I-_G1Sl
    ?         引用CDOEX.DLL;
    
    I-_G1Sl
    I-_G1Sl
    ?         代码写入:
    
    I-_G1Sl
    I-_G1Sl
             Set oMsg = CreateObject("CDO.Message")
    
    I-_G1Sl
    I-_G1Sl
             oMsg.DataSource.Open(“http://BackEndServer/public”)
    
    I-_G1Sl
    I-_G1Sl

    I-_G1Sl

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


    I-_G1Sl


    I-_G1Sl

     


    I-_G1Sl

    Run-time error ‘-2147221164(80040154)’:


    I-_G1Sl

    无法向注册表写入项


    I-_G1Sl


    I-_G1Sl

     


    I-_G1Sl

    FrontEndServer 配置:


    I-_G1Sl

    Windows Advanced Server 2000 内部版本号 2195:Service Pack 2


    I-_G1Sl

    IE 版本:5.00.3315.1000 更新版本:SP2


    I-_G1Sl

    CDOEX.DLL的版本号:6.0.4417.0


    I-_G1Sl

    它所处的位置:C:\Program Files\Common Files\Microsoft Shared\CDO


    I-_G1Sl

    原因


    I-_G1Sl

    首先在FrontEndServer 安装了SQL Server 2000之前,我I-_G1Sl们可以使用CDOEX的IDataSource.Open打开用户邮箱的:


    I-_G1Sl

    _ConnectionPtr pCon = NULL;


    I-_G1Sl

    CComPtr <CDO::IFolder>pFldr;


    I-_G1Sl

    CComPtr <CDO::IDataSource>pSource;


    I-_G1Sl

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


    I-_G1Sl

    pFldr->get_DataSource(&pSource);


    I-_G1Sl

    hr=pSource->Open(bstrURLInbox,


    I-_G1Sl

                                      (IDispatch*)pCon,


    I-_G1Sl

                                      adModeRead,


    I-_G1Sl

                                               adFailIfNotExists,


    I-_G1Sl

                                               adOpenSource,


    I-_G1Sl

                                               bstrUserDomainAccount,


    I-_G1Sl

                                               bstrUserPwd);


    I-_G1Sl

     


    I-_G1Sl

    但是安装了SQL Server之后,MDAC就被更新到了version 2.6!!


    I-_G1Sl

     


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

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


    I-_G1Sl

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


    I-_G1Sl

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


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

    所以,安装了SQL Server 2000之后,请一定从下列站点下载最新的MDAC安装包或者补丁。


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

    小结


    I-_G1Sl

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


    I-_G1Sl

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


    I-_G1Sl

     


    I-_G1Sl

    参考文献:


    I-_G1Sl

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


    I-_G1Sl

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

    84639
  • 返回页面顶端
  • 上一篇:Microsoft SQL Server 2000 的数据转换服务
  • 下一篇:SQL SERVER实用经验技巧集 [一]
  • 返回上一页 打印本文 加入收藏
  • 页面最后更新时间:2011年5月18日