环境

  32位程序如何在windows 64位下运行(64位下ODBC与ASP数据库连接)

一般系统部署的服务器若是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错误。

32位程序如何在WIN64位下运行相关推荐

  1. Windows 32位程序在64位操作系统下运行

    VS2013新建的VC++项目默认的组件平台是32位 要将它编译为64位程序,按以下步骤: 1.点击"Win32"下拉框,打开"配置管理器" 2.点击" ...

  2. 使用VC6将32位程序编译成为64位程序(这个才是可行的)

    山上明月 使用VC6将32位程序编译成为64位程序 看了好多好多资料,自己也太过依赖现有的资料,按部就班不是真理不是真理!!! 主要内容是参照http://www.vckbase.com/docume ...

  3. 【操作系统】如何在linux系统下运行C程序

    如何在linux系统下运行C程序 linux系统与windows系统不同,如何在linux中运行C,我们来看看吧. 工具/原料 Linux虚拟机 电脑 方法/步骤 查看全文 http://www.ta ...

  4. KDE应用如何在GNOME环境下运行?

    KDE应用如何在GNOME环境下运行? 2014/03/19 | 分类: IT技术 | 0 条评论 | 标签: GNOME, KDE 分享到:1 本文由 伯乐在线 - honpey 翻译自 howto ...

  5. fh admin mysql版本_在用mysql-front的时候遇到显示:程序注册时间到期程序将被限制模式下运行。...

    在用mysql-front的时候遇到显示:程序注册时间到期程序将被限制模式下运行. 可以在"帮助"菜单下的点"登记"–>把以下的key复制试试,留下以后需 ...

  6. mysql程序注册时间到期key_MySQL-Front 出现“程序注册时间到期 程序将被限制模式下运行”解决方式...

    在用mysql-front的时候遇到显示:程序注册时间到期程序将被限制模式下运行. 可以在"帮助"菜单下的点"登记"-->把以下的key复制试试,留下以后 ...

  7. windows 32位程序编译成64位

    VS2010新建的VC++项目默认的组件平台是32位 要将它编译为64位程序,按以下步骤: 1.点击"Win32"下拉框,打开"配置管理器" 2.点击" ...

  8. 全球最厉害的 14 位程序员,请收下我的膝盖

    全球最厉害的14位程序员是谁,你知道的有几位呢? 以下排名不分先后: 1. Jon Skeet 个人名望:程序技术问答网站Stack Overflow总排名第一的大神,每月的问答量保持在425个左右. ...

  9. 全球顶级的14位程序员!请收下我的膝盖!

    全球最厉害的14位程序员都有哪些人?接下来让我们一起来看一下让业界膜拜的这十几位顶级编程大神. 注意,排名不分先后. 01 Jon Skeet 个人名望:程序技术问答网站Stack Overflow总 ...

最新文章

  1. Deep learning:三十六(关于构建深度卷积SAE网络的一点困惑)
  2. Google更新机器学习开发套件ML Kit,新增支持自动回复与语言识别
  3. 企业网站Solaris环境DNS服务器创建
  4. TPC性能测试及发布
  5. python怎么画条形图-如何在Bokeh(Python)中绘制水平条形图
  6. 支付和LBS定位对于O2O到底有多重要?
  7. kali无限登录_Kali Linux没有无线网卡?玩个锤纸~
  8. 输出控制台信息到日志 并 通过cronolog对tomcat进行日志切分
  9. Mybatis源码分析之(三)mapper接口底层原理(为什么不用写方法体就能访问到数据库)
  10. C/C++|Qt工作笔记-4种方法判断当前对象(类)名或标识(继承发,typeid法,元对象className()法,Q_CLASSINFO法)
  11. 如何在面试结束后反问面试技术官?
  12. linux 压缩命令
  13. ros中move_group的参数动态设置
  14. SIEM比以往更重要的5个原因
  15. adbe Air/flash swf中不能正常显示系统字体问题的解决方案
  16. 在那里可以下载jar包?
  17. latex如何取消自动编号_latex 取消自动编号
  18. wincc版本升级_【西门子】WinCC V7.4 SP1:常规信息和安装 (较新).pdf
  19. 深入了解FileNet
  20. 高通平台如何抓RAMDUMP

热门文章

  1. 【Shader笔记10】更复杂的光照-Unity的光源类型
  2. 位图和矢量图、分辨率
  3. 在线考试系统源码,线上即可完成考试+刷题+练习等功能的学习系统
  4. H3C交换机Telnet配置
  5. dw本地服务器文件夹,dw设置本地服务器
  6. 失业的程序员(十):分歧的产生
  7. decode null oracle,用decode和nvl处理null值时需要注意的地方
  8. 利用计算机的数字化技术和人机交换,多媒体技术与应用教程(雷运发)课后习题答案(1-4)...
  9. python进程池必须手动关闭
  10. 第一次参加kaggle竞赛:Happywhale - Whale and Dolphin Identification(ID识别问题:top9.4% 150/1558)