使用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.tlb 和Msado60_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.tlb和Msado60_Backcompat_x64.tlb这2个文件;
64位WIN7系统(AMD平台)需要注册:Msado60_Backcompat_i386.tlb和Msado60_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