zoukankan      html  css  js  c++  java
  • 本地windows下PHP连接远程oracle遇到的诸多问题

    任务目的:本地windows下PHP连接远程服务器下的oracle。

    必须必须 确定服务器的数据库版本,如果本地的驱动和对方服务器版本不一致,会导致许多报错。

    已知的oracle版本  分为 32位的10G,11G,13G 64位的10G,11G,13G

    我本机是64位的系统,开始就进去误区,把所有版本的64位下载了一遍,结果 不管你怎么调,本地的驱动就是找不到oci方法。

    然后目标定位到32位,32位如果下载错版本,会报这个错。

    oci_connect(): OCIEnvNlsCreate() failed. There is something wrong with your system - please check that PATH includes the directory with Oracle Instant Client libraries

    找对版本后,下载下来,运行成功。

    其中我的本地由于是新开的,所以很多配置文件都没有,导致执行的过程中缺少各种文件,按照报错缺少的文件逐个去官网(权威点的网站)下载,放到位置可。

    具体操作步骤如下:

       1.打开php.ini,把extension=php_oci8.dll打开。

       2.其中下载oracle包中的oci.dll房到 C盘的sys32?64看你自己的系统是多少位的。

       3.把oracle包中的所有文件拷到php扩展文件夹一份,apache的bin目录一份。

    如果还是不行  那就把php的扩展php_oci8.dll也放到sys32里一份,这点不太确定,查了好多资料都这么说,我第一部就放进去了。

    其中改了许多环境变量什么的,最后问题解决之后才发觉都没用,又都删了。

    最后附上php连接oracle的代码(其中oci_connect中 的SID就是常说的数据库,但是oracle中好像普遍都叫服务名,你就当成数据库名理解就行)

    $conn = oci_connect('username','password',"(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=192.168.0.180)(PORT = 1521))(CONNECT_DATA =(SID=toplw)))");
    $sql = "select * from table";  
    $ora_test = oci_parse($conn,$sql);  //编译sql语句 
    
    oci_execute($ora_test,OCI_DEFAULT);  //执行 
    echo "<pre>";
    while($r=oci_fetch_row($ora_test))  //取回结果 
    {  
        print_r($r);
    }
  • 相关阅读:
    docker 命令(我使用过的)
    docker 概述
    RabbitMq 概述
    spring cloud gateway
    redis-集群(codis和Cluster)
    jdbc 简单示例和优缺点
    git
    Mycat--概述
    线程池
    同步容器和并发容器
  • 原文地址:https://www.cnblogs.com/inc-is-include/p/5398360.html
Copyright © 2011-2022 走看看