场景
我在windows server 2008上用vs2005编译的程序在windows server 2003跑不行,调试发现是ado失败了
测试例子
#include <iostream>
#include <comip.h>
#import " msado15.dll" no_namespace rename("EOF","EndOfFile")
int main()
{
_ConnectionPtr m_pConnection;
::CoInitialize(NULL);
HRESULT hr = m_pConnection.CreateInstance (__uuidof (Connection));
if (SUCCEEDED (hr)) {
std::cout<<"succed!!!!!"<<std::endl;
}
if (FAILED (hr)) {
std::cout<<"failed!!!!!"<<GetLastError()<<std::endl;
std::cout<<"hr="<<hr<<std::endl;
_com_error e(hr);
std::cout<<e.ErrorMessage()<<std::endl;
return -1;
}
return 0;
}
在windows server 2003运行结果为:
原因
因为有些 ADO 接口更改与新实例标识符 (Iid) 相关联的 Windows 7 SP1 中,将出现此问题。较旧的 IID 接口分配给以下后缀:
- 在 Windows 7 和更早版本的 Windows 中,_Connection IID 是 00000550-0000-0010-8000-00AA006D2EA4。
- 在 Windows 7 SP1 中,_Connection IID 00001550-0000-0010-8000-00AA006D2EA4,并且 _Connection_Deprecated IID 00000550-0000-0010-8000-00AA006D2EA4。
是与平台相关的一些 ADO Api 在 ADO 中 2.7 及更高版本。在 64 位版本的 Windows,这些 ADO Api 使用 64 位数据类型 (如LONGLONG数据类型) 来处理参数。但是,使用这些 Api 的应用程序仍使用长数据类型。因此,当您尝试运行该宏时收到一条"类型不匹配"错误消息。
解决方案
1、将Msado60_Backcompat_i386.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 (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.32位系统把Msado60_Backcompat_i386.tlb名字改成msado60_Backcompat.tlb,放在项目下;
64位系统(INTEL平台)把Msado60_Backcompat_x64.tlb名字改成msado60_Backcompat.tlb,放在项目下;
64位系统(AMD平台)把Msado60_Backcompat_ia64.tlb名字改成msado60_Backcompat.tlb,放在项目下;
5、重新生成解决方案即可
参考:
http://blog.csdn.net/magic_andy/article/details/9225073
http://blog.csdn.net/jianzhanger/article/details/8970554