vs2010 MFC +win7下的程序 在win7上正常运行,XP就出错(ADO数据库连接出错)
2015-09-02 08:56
281 查看
写的一个软件,以数据库文件mdb作为打开文件。
使用ADO连接数据库, 引入了msado15.dll。以前一直很正常。
最近的版本总是在xp上测试打开、新建文件都失败。出现的错误是unknow software exception...
找了几天错误,终于发现不是自己的代码问题。而可能是编译环境问题。于是重装了两次vs2010。问题依旧。
好不容易找到下面这篇文章。发现是ado的问题。按流程操作后测试可以正确运行。
http://hi.baidu.com/hxin1116/item/68018488c07b76c799255f36
我的机子是WIN7系统,在WIN7下开发的MFC ADO应用程序到XP上就不能运行了。
解决方案如下:
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、拿[b]32位系统示例[/b]
注册Msado60_Backcompat_i386.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\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、重新生成解决方案即可
使用ADO连接数据库, 引入了msado15.dll。以前一直很正常。
最近的版本总是在xp上测试打开、新建文件都失败。出现的错误是unknow software exception...
找了几天错误,终于发现不是自己的代码问题。而可能是编译环境问题。于是重装了两次vs2010。问题依旧。
好不容易找到下面这篇文章。发现是ado的问题。按流程操作后测试可以正确运行。
http://hi.baidu.com/hxin1116/item/68018488c07b76c799255f36
ADO 应用程序不在运行级别较低的操作系统运行的解决方案
我的机子是WIN7系统,在WIN7下开发的MFC ADO应用程序到XP上就不能运行了。解决方案如下:
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、拿[b]32位系统示例[/b]
注册Msado60_Backcompat_i386.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\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、重新生成解决方案即可
相关文章推荐
- VC连接ADO方式ACCESS数据库在WIN7下编译到XP下不能运行解决方法
- sqlserver 安装“ 0x8 ”系列报错解决
- NSQ系列之nsqlookupd代码分析四(详解nsqlookupd中的RegitrationDB)
- MySQL for mac 安装
- mysql 数据库某字段中某段文字的替换
- Oracle数据库远程连接的方法
- CQL3语法简介
- MySQL 取得两个时间相差的分钟数 及 常用时间函数
- Oracle 11g sys,system,scott密码重新设置方法
- mysql 日志监控
- 对比Oracle临时表和SQL Server临时表的不同点
- 详解Oracle数据库各类控制语句的使用
- 详解MySQL集群搭建
- MySQL中VARCHAR与CHAR格式数据的区别
- 安装MySQL常见的三种方式
- mysql
- oracle数据库导入导出imp/exp
- Codis作者黄东旭细说分布式Redis架构设计和踩过的那些坑们
- MySQL存储过程之安全策略
- 解决64位Oracle使用32位PLSQL Developer的乱码问题