• C# System.Data.OracleClient requires Oracle client software version 8.1.7 or greater


    好好的程序,突然出现了错误,原因是:System.Data.OracleClient requires Oracle client software version 8.1.7 or greater,很是奇怪

    服务器上的oracle明明是10g,程序出错就也不提示8.1.7啊,百度了一下,发现有解决方法如下:

    原来当Oracle 9.2运行在NTFS的分区上时,对于某些非administrator组的用户,ORACLE_HOME 目录是不可见的,而在windows server 2003下asp.net应用使用的帐户是netword service,因此无法创建oracle连接,只要重设一下ORACLE_HOME目录的权限就可以了。步骤如下:
    1、以管理员的用户登录;
    2、找到ORACLE_HOME文件夹(我的是C:oracleora92),点右键,选属性--安全,在组或用户栏中选“Authenticated Users”,在下面权限列表中把“读取和运行”的权限去掉,再按应用;重新选上“读取和运行”权限,点击应用;选权限框下面的“高级”按钮,确认“Authenticated Users”后面的应用于是“该文件夹、子文件夹及文件”,按确定把权限的更改应用于该文件夹;
    3、重新启动计算机,让权限设置生效(请注意,这一步很重要);
    4、登录后运行asp.net应用,正常取得Oracle数据库的数据。  
    看到这里,我想起来了,于是去看了看环境变量中的oracle路径,发现在果然是这样。原来前几天在服务器上,突然发现在有两块硬盘,一直没有用,连盘符也没有分,光驱在D盘,oracle装在E盘。看着心里别扭,就把光驱调到最后,设为H盘,E盘则改为D盘,新加的两个硬盘,分别有E、F。 

    硬盘盘符调好了,但是环境变量里面的路径没变,oracle的路径还是在E盘,没办法,只好又把硬盘盘符恢复成之前的,问题解决。

  • 相关阅读:
    struts2乱码
    修改maven的war包生成路径
    cookie的坑
    linux jps 命令
    (转)如何使VMware ip与本机ip处于同一网段
    springboot + swagger2 学习笔记
    can not find java.util.map java.lang.Double问题
    为什么不写 @RequestParam 也能拿到参数?
    乱码问题
    PostMan的使用注意事项
  • 原文地址:https://www.cnblogs.com/chendaoyin/p/3506989.html
Copyright © 2020-2023  润新知