win2003 64位系统下ODBC连接使用方法
环境
一般系统部署的服务器若是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错误。
完成以上修改后,重启电脑,运行网站程序,发现一切都如期望的一样工作!
祝大家好运!
相关文章
- 这篇文章主要介绍了C#使用ODBC与OLEDB连接数据库的方法,结合实例形式分析了C#基于ODBC与OLEDB实现数据库连接操作简单操作技巧,需要的朋友可以参考下...2020-06-25
MySQL学习第三天 Windows 64位操作系统下验证MySQL
MySQL学习第三天教大家如何在Windows 64位操作系统下验证MySQL,感兴趣的小伙伴们可以参考一下...2016-06-12- 今天帮一客户配置他的64位windows 2003下的php运行环境的时候.发现的这个问题,通过以下方法解决,特分享下,方便需要的朋友...2016-01-27
- 这篇文章主要介绍了go语言通过odbc访问Sql Server数据库的方法,实例分析了Go语言通过odbc连接与查SQL Server询数据库的技巧,需要的朋友可以参考下...2020-05-07
win2008 R2中安装MySQL出现ODBC连接器安装错误
这篇文章主要介绍了win2008 R2中安装MySQL出现ODBC连接器安装错误,需要的朋友可以参考下...2016-07-04- [标签:特殊页filename]...2016-01-27
- 这篇文章主要介绍了C#连接ODBC数据源的方法,实例分析了C#连接ODBC操作数据库的技巧,非常具有实用价值,需要的朋友可以参考下...2020-06-25
MySQL学习第四天 Windows 64位系统下使用MySQL
MySQL学习第四天教大家如何在Windows 64位下使用MySQL,即使用命令行方式完成操作MySQL服务,感兴趣的小伙伴们可以参考一下...2016-06-12- 这篇文章主要介绍了VC实现ODBC数据库操作的方法,非常有实用价值,需要的朋友可以参考下...2020-04-25
- 现在网上恶意攻击日益增多,人们都不想被他人搜索到自己的IP地址以求安全,那么到底有什么办法可以使自己的服务器在在线状态下逃脱搜索呢?...2016-01-27
- 这篇文章主要介绍了go语言通过odbc操作Access数据库的方法,实例分析了Go语言通过odbc连接、查询与关闭access数据库的技巧,需要的朋友可以参考下...2020-05-07
- 一般系统部署的服务器若是windows系统,就会采用64位win2003的结构。可是我们编写的程序绝大多数都是在x86下32位cpu架构中编译的,要正常移植到64位机器还真的是很麻烦,不仅要求应用程序是64位模式编译,还需要数据库也得是64位,iis64位...2017-07-06
在Win2003(64位)中配置IIS6+PHP5.2.17+MySQL5.5的运行环境
这篇文章主要介绍了在Win2003(64位)中配置IIS6+PHP5.2.17+MySQL5.5的运行环境,需要的朋友可以参考下...2016-04-07在dell PowerEdge 2950上安装win2003 server的方法介绍
本文介绍下,在dell PowerEdge 2950上,安装windows 2003 server的方法,以及遇到的一些问题与解决方法,有遇到类似问题的朋友,可以参考下...2016-01-27- 原来的IIS好像有点问题,就下载了win2003的IIS6,卸了IIS重装,结果asp怎么都配不起来。...2016-01-27