当前位置: 首页 > 图文教程 > 网络编程 > ASP > 解决使用ASP无法连接ORACLE 9i数据库的问题

ASP
ASP 编程中20个非常有用的例子(一)
ASP 编程中20个非常有用的例子(二)
ASP基础教程:ADO存取数据库时如何分页显示
ASP基础教程:其它的ASP常用组件
ASP基础教程:学习ASP中子程序的应用
ASP基础教程之ASP程序对Cookie的处理
ASP基础教程之实例学习ASP Response 对象
ASP基础教程之ASP AdRotator 组件的使用
ADO初学者教程:ADO 通过GetString()加速脚本
初学者来认识OLEDB和ODBC的区别
ASP常见数学函数 Abs Atn Cos 等详细详解
VBScript新手入门初学教程:VBScript简介
有用的无声递交表单的客户端函数
Windows 2003 安装设置iis
ASP技巧实例:几行代码解决防止表单重复提交
ASP读sql数据时出现乱码问题的解决方法
ASP技巧实例:使用ASP记录在线用户的数量
ASP技巧实例:关于对表单操作的程序
ASP技巧实例:ASP实现最简洁的多重查询的解决方案
ASP实例:利用缓存提高数据显示效率

解决使用ASP无法连接ORACLE 9i数据库的问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 35 ::
收藏到网摘: n/a

       今天,在一台WIN2K SERVER 服务器上,通过ASP安装在本机的 Oracle9i 数据库时,发现错误,根本无法连接上数据库。其错误描述如下:
  
  Microsoft OLE DB Provider for ODBC Drivers 错误 '80004005'
  [Microsoft][ODBC 驱动程序 管理器] 驱动程序的 SQLAllocHandle on SQL_HANDLE_ENV 失败
  
  或
  
  Microsoft OLE DB Provider for ODBC Drivers 错误 '80004005'
  由于系统错误 5 (Oracle in jxt_user),导致不能加载指定驱动程序
  
  连接方式是通过ODBC,驱动程序包括 Oracle ODBC Driver 和 Microsoft ODBC Driver for Oracle 。
  连接字串如下:
  (1)CONNECTIONSTRING ="DSN=TXLTNS;UID=user;PWD=password"
  (2)CONNECTIONSTRING ="DRIVER={Oracle in txl_user};UID=user;PWD=password;DBQ=TXLTNS;DBA=W;"
  
  结果,都是无法正常运作。经检查发现 %ORACLE_HOME% 设置是正确的,也包含到PATH中了。
  
  
  在 GOOGLE 搜索简体中文的信息,发现一个信息说法如下:
  “这个其实是由于Oracle9i装在2000的NTFS分区上产生的错误。主要是IIS的权限不足,找不到Oracle9i的文件导致的错误。”
  而且他还给出了一堆英文文摘,答题的意思是:%ORACLE_HOME%这个目录在安装的时候,是单独设置了权限的,默认是管理员组、SYSTEM组和一个名为“Authenticated Users”的组具有权限。他还说要这样:
  ------------------------------------------
  v. Click on "Authenticated Users" item in the "Name" list (on Windows XP the "Name" list is called "Group or user names").
  vi. Uncheck the "Read and Execute" box in the "Permissions" list (on Windows XP the "Permissions" list is called "Permissions for Authenticated Users"). This box will be under the "Allow" column.
  vii. Check the "Read and Execute" box. This is the box you just unchecked.
  ------------------------------------------
  
  感觉这段英文的说法有点怪,为什么要取消Authenticated Users组的“读取和执行”权限呢,不是说权限不够吗?
  
  继续在ORACLE 技术网查询相关信息,发现这个信息:
  -------------------------------------------
  The Microsoft ODBC driver for Oracle is known not to work correctly on a 9.2 Oracle client. You need to use the Oracle ODBC driver if you're using the 9.2 client.
  -------------------------------------------
  
  这样看来,这个错误的发生,与ORACLE的安装配置无关。因为之前测试过使用JAVA通过 JDBC 连接ORACLE是成功的。
  
  于是下载最新的 MDAC2.8 ,安装完后,重新启动计算机,再测试原来的ASP程序,发现已经成功连接到ORACLE数据库。
  
  前面别人说的“权限”问题,看来在这里并不适应。呵呵。
  
  附:
  MDAC2.8 的下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=6c050fe3-c795-4b7d-b037-185d0506396c