数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
安装SQL Server2K可能引发一个严重问题

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

 

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

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

 

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)

 




相关文章

相关软件