好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Windows 2003 X64环境中配置ODBC数据源 - Windows操作系

Windows 2003 X64环境中配置ODBC数据源

 

win+r

默认调用的odbcad32是在c:\windows\system32下,是64位的odbc配置工具,32位的配置工具在c:\windows\syswow64下,找到odbcad32并执行添加数据源。

  HdhCmsTest2cto测试数据  

  环境

 

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

 

  分析  HdhCmsTest2cto测试数据  

 

  对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位的方法  HdhCmsTest2cto测试数据  

 

  若以前系统运行在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查询中文会是乱码)

 

 

  3、修改Path增加D:\oracle\instantclient_11_2,同时删除原来64位oracle的路径

 

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

 

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

 

  Windows Registry Editor Version 5.00 

    HdhCmsTest2cto测试数据  

以下是代码片段:

    [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错误。

 

查看更多关于Windows 2003 X64环境中配置ODBC数据源 - Windows操作系的详细内容...

  阅读:44次