文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

本文介绍:

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

背景介绍:

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

按正常步骤:

1、oracle官网(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:\oracle目录;


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

path: 中添加d:\oracle\;

新建ORACLE_HOME: 值为d:\oracle\;

新建TNS_ADMIN: 值为d:\oracle\network\admin\;

有需要的话还得新建NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK 或者

AMERICAN_AMERICA.ZHS16GBK

4、开始-运行-cmd 进入d:\oracle目录并执行./odbc_install.exe

可见到

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

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


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

可以看到oracle的驱动了

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


6、问题来了:无法加载 Oracle in instantclient_11_2 ODBC 驱动程的安装例程,因为存在系统错误代码 14001

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

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

想了各种办法,无果,甚至连操作系统都重装了,也无效。(我这是一个干净的系统,啥都没装。其实这是个线索,因为我啥都没装!!!!!!!!)

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

故障分析

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

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

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

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

无法加载 Oracle in instantclient Driver 驱动程的安装例程,因为存在系统错误代码 126

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

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

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


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


问题陷入了僵局。。。。。。


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

a、将oracle odbc还原到11.2.0.4.0版本并安装odbc(参照上方的安装步奏)

b、执行odbcad32程序,选择oracle odbc 驱动,但先不点击

c、打开cmd,运行 SxsTrace Trace -logfile:d:\SxsTrace.etl(将日志写入d:\SxsTrace.etl)

d、点击odbcad32--oracle odbc 驱动--完成

e、出现14001报错

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

g、SxsTrace Parse -logfile:d:\SxsTrace.etl -outfile:d:\SxsTrace.txt

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

h、打开生成的日志d:\SxsTrace.txt

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

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

错误: 无法解析参考 Microsoft.VC80.MFC,processorArchitecture="x86",publicKeyToken="1fc8b3b9a1e18e3b",type="win32",version="8.0.50727.762"。

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

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

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

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


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

那么怎么解决呢?

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

屁颠屁颠地跑微软官网去下一个32位的vcredist_x86

Microsoft Visual C++ 2005 SP1 Redistributable Package (x86)

http://www.microsoft.com/zh-cn/download/confirmation.aspx?id=5638

双击安装vcredist_x86,完毕

满怀期待地打开odbcad32,选择oracle odbc driver项,然后.............

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

熟悉的界面终于出现了。。。。。。。真是喜大普奔啊~~~~~~~~~~~




希望我跟oracle odbc 曲折的斗争史能给大家一点启发和借鉴。

通过相关跟踪工具的使用,排查和锁定故障原因。最终能够独立解决这个问题,让我挺欣慰。


windows server 2008 r2 x64系统安装oracle instantclient odbc 32位程序,需要在系统中安装vcredist_x86环境

64位的oracle odbc安装也就没有问题啦,区别是使用的是system32\odbcad32.exe程序来添加odbc即可。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯