环境

一般系统部署的服务器若是windows系统,就会采用64位win2003的结构。可是我们编写的程序绝大多数都是在x86下32位cpu架构中编译的,要正常移植到64位机器还真的是很麻烦,不仅要求应用程序是64位模式编译,还需要数据库也得是64位,iis64位,framework64位,好在相应的厂商都提供这些支持组件。不知道有人遇到过像我这样的问题么,应用中有需要增加一个Access数据库导入功能,这就需要连接ODBC的mdb驱动,可是Microsoft OLE DB Provider for Jet不支持64位系统,即使安装了office2007后,发现ODBC也没有任何变化,这下尴尬了。

分析

对64位系统结构进行分析。

c盘下有两个程序安装目录:Program Files和Program Files (x86);
windows文件夹下有两个目录:System32和SysWOW64;
在System32中的odbcad32.exe中没有其他驱动(这也是控制面板中ODBC直接启动的程序),但是在SysWOW64下的odbcad32.exe却存在mdb之类的所有驱动,这说明ODBC驱动在操作系统中是存在的,只是因为运行模式导致调用的odbc程序不同,造成找不到对应的驱动。了解到这一点,就能找到解决方案:切换64位运行模式为32位。

解决步骤

切换IIS运行模式为32位

开始→运行→cmd,运行脚本:

cscript %SYSTEMDRIVE%\inetpub\adminscripts\adsutil.vbs SET W3SVC/AppPools/Enable32bitAppOnWin64 1

即可将IIS由64位切换为32位模式;若想恢复为64位模式,运行脚本:cscript %SYSTEMDRIVE%\inetpub\adminscripts\adsutil.vbs SET W3SVC/AppPools/Enable32bitAppOnWin64 0。若脚本报错,切换路径为C:\Inetpub\AdminScripts,因为adsutil.vbs文件在该路径下。

Asp.net运行模式为32位

重新注册asp.net,开始→运行→cmd

运行脚本:%SYSTEMROOT%\Microsoft.NET\Framework\v2.0.40607\aspnet_regiis.exe -i

若要注册64位,脚本为:%SYSTEMROOT%\Microsoft.NET\Framework64\v2.0.40607\aspnet_regiis.exe -i

重启机器,IIS即可运行32位的程序,ODBC的连接也生效了。

Oracle64位切换为32位的方法

若以前系统运行在64位模式下使用的是64位的oracle,修改为32位模式后程序的数据库连接就失败,会报:“如果在安装 32 位 Oracle 客户端组件的情况下以 64 位模式运行……”这个错误。想到的方法自然是再安装32位的oracle客户端了。其实最简单的方法是下载ORALCE工具包Instant Client Package。将其解压到任意文件夹下,如D:\oracle\instantclient_11_2。

设置对应的环境变量:右击”我的电脑” – “属性” – “高级” – “环境变量” – “系统环境变量”:
1、新建NLS_lANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK(注意中间有空格,这个如果不设,toad查询中文会是乱码)
2、新建或修改TNS_ADMIN=D:\oracle\instantclient_11_2
3、修改Path增加D:\oracle\instantclient_11_2,同时删除原来64位oracle的路径

其中第一条很重要,解决运行时报:Ora-12705: cannot access nls data files or invalid environment specified的错误。

新建文本文件,修改后缀名为reg,内容为:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_OraClient10g_home1] 
”NLS_LANG”=”SIMPLIFIED CHINESE_CHINA.ZHS16GBK” 
”ORACLE_BUNDLE_NAME”=”Standard” 
”ORACLE_GROUP_NAME”=”Oracle – OraClient10g_home1″ 
”ORACLE_HOME”=”D:\oracle\instantclient_11_2” 
”ORACLE_HOME_KEY”=”SOFTWARE\\ORACLE\\KEY_OraClient10g_home1″ 
”ORACLE_HOME_NAME”=”OraClient10g_home1″

双击导入注册表。

将64位oracle的tns文件拷入D:\oracle\instantclient_11_2中,否则运行会报:ORA-12154: TNS:could not resolve the connect identifier specified错误。

完成以上修改后,重启电脑,运行网站程序,发现一切都如期望的一样工作!

祝大家好运!

标签:
win2003,64,ODBC

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
评论“win2003 64位系统下ODBC连接使用方法”
暂无“win2003 64位系统下ODBC连接使用方法”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。