我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决

本文介绍:

在windows server 2008 r2 (x64)环境下安装甲骨文instantclient odbc方法

背景介绍:

因我搭建的服务器为64位系统,但所使用的应用为32位,所以需要安装32位的oracle odbc。

按正常步骤:

1,甲骨文官网(http://www.oracle.com/technetwork/database/features/instant - client/index - 097480. - html)下载以下32位包:(我选择旧点的版本11.2.0.4.0)

instantclient-basic-nt-11.2.0.4.0.zip instantclient-odbc-nt-11.2.0.4.0.zip

instantclient-sqlplus-nt-11.2.0.4.0.zip


2,将所有包解压到d: \甲骨文目录;


3,配置系统的环境变量:

路径:中添加d: \甲骨文\;

新建ORACLE_HOME:值为d: \甲骨文\;

新建TNS_ADMIN:值为d: \甲骨文\网络\ admin \;

有需要的话还得新建NLS_LANG=

4,开始,运行- cmd进入d: \甲骨文目录并执行。/odbc_install。exe

可见到

我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决

如需卸载odbc,则同路径下执行odbc_uninstall。exe;


5,因为是64位系统运行32位odbc,则需要使用C: \ Windows \ SysWOW64 \ odbcad32。exe

可以看到甲骨文的驱动了

我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决


6,问题来了:无法加载甲骨文在instantclient_11_2 odbc驱动程的安装例程,因为存在系统错误代码14001

我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决

遇到如上问题,网上查了诸多资料都是说环境变量问题而已,均不能解决我的问题。

想了各种办法,无果,甚至连操作系统都重装了,也无效。

=========================================================================

=========================================================================

我以为是odbc版本问题,又从oracle官网上下载12.1.0.2.0等版本来测试

环境变量仍按标准的甲骨文odbc的设置方法,仅仅是用其他版本来替换文件并安装odbc

报错仍然出现,只是报错代码变了:

无法加载甲骨文instantclient司机驱动程的安装例程,因为存在系统错误代码126

我用Procmon.exe程序来跟踪odbcad32的进程pid,发现程序没发现2个DLL文件。

于是在D: \甲骨文目录中添加mfc100.dll和msvcr100。dll文件(网上下载)。

再次odbcad32执行odbc添加,报错依旧,只是错误代码又变了:错误代码127


这下子我再用procmon来跟踪进程已经无果了,没有发现其他相关的依赖文件。


问题陷入了僵局…


最后忍无可忍,那就用SxsTrace。exe吧,,这是个用来跟踪程序的东东,步骤:

,将甲骨文odbc还原到11.2.0.4.0版本并安装odbc(参照上方的安装步奏)

b,执行odbcad32程序,选择甲骨文odbc驱动,但先不点击

c,打开cmd,运行,SxsTrace跟踪日志文件:d: \ SxsTrace.etl(将日志写入d: \ SxsTrace。etl)

d点击odbcad32——甲骨文odbc驱动,完成

e,出现报14001错

f,在cmd窗口下敲回车,结束跟踪

g、d: \ SxsTrace SxsTrace解析日志文件。etl输出文件:d: \ SxsTrace。txt

我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决

h,打开生成的日志d: \ SxsTrace。txt

扫了一眼都是些没太大用途的日志,直到最后一句出现“错误”字样时引起我注意:

=========================================================================================

错误:无法解析参考Microsoft.VC80.MFC, processorArchitecture=皒86”,都必须“1 fc8b3b9a1e18e3b类型=皐in32 version=" 8.0.50727.762 " .

错误:生成激活上下文失败。

=========================================================================================

看到这里大家有没有什么想法呢?

我的第一想法就是:不是吧..... VC8 .....微软。VC80 .....这代表着什么?是VC没错吧? D: \甲骨文目录里也有VC8, VC9目录,不是么?


我这时就看到一丝曙光.....我饶了一个大弯,原来是VC问题…

那么怎么解决呢?

我想了下无非就是运行环境嘛,那我去装个vc++的运行环境

我跟甲骨文odbc做斗争! win2008 r2 64位安装甲骨文instantclient odbc方法和故障解决