ADO数据库连接问题-win7下mfc开发程序在XP系统下连接问题

场景

我在windows server 2008上用vs2005编译的程序在windows server 2003跑不行,调试发现是ado失败了


测试例子

[cpp]  view plain copy
  1. #include <iostream>  
  2. #include <comip.h>  
  3.   
  4. #import " msado15.dll" no_namespace rename("EOF","EndOfFile")  
  5.   
  6. int main()  
  7. {     
  8.        _ConnectionPtr m_pConnection;  
  9.         ::CoInitialize(NULL);   
  10.   
  11.         HRESULT hr = m_pConnection.CreateInstance (__uuidof (Connection));  
  12.     if (SUCCEEDED (hr)) {  
  13.         std::cout<<"succed!!!!!"<<std::endl;  
  14.     }  
  15.   
  16.     if (FAILED (hr)) {  
  17.         std::cout<<"failed!!!!!"<<GetLastError()<<std::endl;  
  18.         std::cout<<"hr="<<hr<<std::endl;  
  19.         _com_error e(hr);  
  20.         std::cout<<e.ErrorMessage()<<std::endl;  
  21.         return -1;  
  22.     }  
  23.     return 0;  
  24.  }   
在windows server 2003运行结果为:


原因

因为有些 ADO 接口更改与新实例标识符 (Iid) 相关联的 Windows 7 SP1 中,将出现此问题。较旧的 IID 接口分配给以下后缀:

_Deprecated
例如,接口 _Connection 已更新,如下所示:
  • 在 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。
如果您的应用程序使用早期绑定到 _Connection,二进制编译过程中的应用程序中存储新的 IID。 IID 不存在,因此,在低级别的操作系统上运行应用程序时,这会导致错误。

是与平台相关的一些 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.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.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

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 黑客帝国 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值