• 本地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);
    }
  • 相关阅读:
    数组
    基本类型与封装类
    类与对象以及引用以及内存
    (一)eclipse Dynamic web project 工程目录以及文件路径问题
    jdbc
    连接
    curl命令
    java annotation
    websocket
    Trie(前缀树)和ternary trie和binary search tree
  • 原文地址:https://www.cnblogs.com/inc-is-include/p/5398360.html
Copyright © 2020-2023  润新知