码迷,mamicode.com
首页 > 数据库 > 详细

本地windows下PHP连接远程oracle遇到的诸多问题

时间:2016-04-16 15:22:59      阅读:214      评论:0      收藏:0      [点我收藏+]

标签:

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

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

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

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

然后目标定位到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);
}

 

本地windows下PHP连接远程oracle遇到的诸多问题

标签:

原文地址:http://www.cnblogs.com/inc-is-include/p/5398360.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!