Linux下PHP支持oracle,安装oracle instant client,pdo_oci笔记
安装篇
首先,PHP支持oracle我首先想到的是pdo相关驱动,看了一下还真有,叫做pdo_oci。
但还依赖 oracle instant client ,这个要到oracle官网下载:
http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html
选择对应系统的版本,点击进去,这里我的是64位linux,所以选择 Instant Client for Linux x86-64 ,之后会让你同意一个协议,叫做 Accept License Agreement ,勾选后就可以下载了。
值得一提的是,如果要通过wget方式下载,你需要注册一个oracle账号并登陆,然后先在自己电脑上点击下载,得到一个实际url(包含一个token),复制这个url去服务器上wget,直接wget网页里的url是下不了的,切记。
需要下载两个包:
oracle-instantclient12.1-basic-12.1.0.2.0-1.x86_64.rpm
oracle-instantclient12.1-devel-12.1.0.2.0-1.x86_64.rpm
版本号可能不一样,看下关键词:basic 和 devel即可。
这两个包下载到服务器上,分别安装:
rpm -ivh oracle-instantclient12.1-basic-12.1.0.2.0-1.x86_64.rpmrpm -ivh oracle-instantclient12.1-devel-12.1.0.2.0-1.x86_64.rpm
因为是64位系统,为了防止编译php扩展出问题,将刚刚安装好的两个目录做个软连接
ln -s /usr/lib/oracle/12.1/client64 /usr/lib/oracle/12.1/clientln -s /usr/include/oracle/12.1/client64 /usr/include/oracle/12.1/client
ok,下一步就开始安装 pdo_oci扩展。
首先你应该有一份php源码,如果没有,请到官网下载一份对应版本的。
假设我的源码在 /home/src/php56
cd /home/src/php56cd ext/pdo_ociphpize #注释:如果没有这个命令你需要找到php安装目录的bin/,如/usr/local/php/bin/phpize./configure --with-pdo-oci=instantclient,/usr,12.1 --with-php-config=/usr/bin/php-config#注:12.1需要对应上面安装的oracle instant的版本号,和oracle/12.1的数字一样,--with-php-config是和phpize同理,在php安装目录里的bin目录下,这两个要改成自己实际情况的。make && make install
如果顺利的话,编译成功后,修改 php.ini ,在文件末尾空两行,加上
extension=pdo_oci.so;
好了,通过
php -m
命令看一下有没有PDO_OCI这一行,有的话就是ok了。
web服务记得要重启apache或php-fpm。
使用篇
使用过程跟pdo差不多,我对oracle还不是很了解,但是也遇到一个故障,那就是无法连接oracle。
一开始通过下面的方式连接:
$pdh = new PDO('oci:dbname=IP地址:端口号/SID',用户名,密码);
报错:
SQLSTATE[HY000]: pdo_oci_handle_factory: ORA-12514: TNS:listener does not currently know of service requested in connect descriptor
后来在statckoverflow上找到答案,改成下面这种连接方式:
$tns = " (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 你的IP)(PORT = 端口号)) ) (CONNECT_DATA = (SID = 你的oracle数据库的SID) ) ) ";$db_username = "youname";$db_password = "yourpassword";try{ $conn = new PDO("oci:dbname=".$tns,$db_username,$db_password);}catch(PDOException $e){ echo ($e->getMessage());}
这样就没问题了。