任务目的:本地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 "
";while($r=oci_fetch_row($ora_test)) //取回结果
{
print_r($r);
}
原文:http://www.cnblogs.com/inc-is-include/p/5398360.html
本文详述了在本地Windows系统下使用PHP连接远程Oracle服务器时遇到的问题及解决方案,包括驱动版本匹配、环境配置、错误处理等关键步骤,通过设置php.ini、放置oci.dll文件和调整环境变量等方法成功建立连接。
160

被折叠的 条评论
为什么被折叠?



