ado 0x80004002

使用ado连接oracle,win7下是好的,跑到另外一台server2003不能用了,报0x80004002

//_ConnectionPtr m_pConnection;

hr1 = m_pConnection.CreateInstance(__uuidof(Connection));
if(hr1 != S_OK)
{
    m_strLastError.Format("CreateInstance fail:%08x", hr1);
    return FALSE;
}

原因:使用win7 64位自带的msado15.dll编译链接数据库的软件只能在win7上运行,不能在xp上运行

解决方法1:

1、先下载下面的文件

32位WIN7系统:Msado60_Backcompat_i386.tlb

64位WIN7系统(INTEL平台):Msado60_Backcompat_i386.tlb 和Msado60_Backcompat_x64.tlb

64位WIN7系统(AMD平台):Msado60_Backcompat_i386.tlbMsado60_Backcompat_ia64.tlb

2、拿64位WIN7系统(INTEL CPU)示例

注册msado60_Backcompat_x64.tlb

1、将Msado60_Backcompat_x64.tlb复制到C:\Program Files\Common Files\System\ado\目录下

2、再将C:\Windows\Microsoft.NET\Framework\v4.0.30319\regtlibv12.exe复制到C:\Program Files\Common Files\System\ado\目录下

3、运行CMD,

       分别输入:

             pushd C:\Program Files\Common Files\System\ado\回车
             regtlibv12.exe msado60_Backcompat_x64.tlb回车

注册msado60_Backcompat_i386.tlb

1、将Msado60_Backcompat_i386.tlb复制到C:\Program Files (x86)\Common Files\System\ado\目录下

2、再将C:\Windows\Microsoft.NET\Framework\v4.0.30319\regtlibv12.exe复制到C:\Program Files (x86)\Common Files\System\ado\目录下

3、运行CMD,

        分别输入:

               pushd C:\Program Files (x86)\Common Files\System\ado\回车
               regtlibv12.exe msado60_Backcompat_i386.tlb回车

注意:

32位系统需要注册Msado60_Backcompat_i386.tlb

64位WIN7系统(INTEL平台)需要注册:Msado60_Backcompat_i386.tlbMsado60_Backcompat_x64.tlb这2个文件;

64位WIN7系统(AMD平台)需要注册:Msado60_Backcompat_i386.tlbMsado60_Backcompat_ia64.tlb这2个文件;

3、替换程序代码

如果是VC++

将:

#import "msado15.dll" no_namespace rename("EOF","EndOfFile")

替换为:

#import "msado60_Backcompat.tlb" no_namespace rename("EOF","EndOfFile")

4、重新生成解决方案即可

转自:http://hi.baidu.com/hxin1116/item/68018488c07b76c799255f36

ps:上面说了半天,不如直接用下面的,反正win7也有,没有再去下呗

#import "C:\Program Files\Common Files\System\ado\msado60.tlb" rename_namespace("ADODB") rename("EOF", "EndOfFile")

解决方法2:拷贝xp电脑上的msado15.dll到win7下,进行编译

#import "lib\xp_32\msado15.dll" rename_namespace("ADODB") rename("EOF", "EndOfFile")

参考:

http://support.microsoft.com/kb/2517589

http://support.microsoft.com/kb/2640696

http://blogs.msdn.com/b/psssql/archive/2011/10/03/yes-we-made-a-mistake-and-are-finally-going-to-fix-it.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值