php7.2怎么连接oracle数据库?OCI8扩展的安装
做项目的时候,远程的oracle数据库为我们提供一张中间表,我这边业务中的一些数据是需要到oracle数据库中的这张中间表去查询的。
PHP连接oracle数据库。需要用到OCI8的扩展。说来惭愧,工作这么多年,还没有正经的使用过oracle数据库。
mysql数据库的语法跟oracle数据库的语法是不一样的,别跟我似的上来就用mysql的语法来操作oracle数据库……有点丢人了……
今天我们大概记录一下OCI8扩展的安装过程。
一:下载文件
1 :oracle官网下载地址:
http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html
下载文件(看准了文件名):
oracle-instantclient19.8-basic-19.8.0.0.0-1.x86_64.rpm
oracle-instantclient19.8-devel-19.8.0.0.0-1.x86_64.rpm
2 :PHP官网下载地址:
https://www.php.net/manual/zh/oci8.installation.php
PHP-OCI8插件
下载命令:
wget http://pecl.php.net/get/oci8-2.2.0.tgz
建议将以上三个文件放入/opt目录下,当然,具体放哪是你的自由。能找到就行。
二:安装
1 :安装oracle插件
rpm -ivh oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
rpm -ivh oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm
可能会报错:
ImportError: libaio.so.1: cannot open shared object file: No such file or directory”
报错原因上边已经给出,缺少libiao插件,解决方法:
yum install libaio
2 :安装OCI8插件
(1):解压tar包:
tar -zxf oci8-2.2.0.tgz
(2):进入解压目录
cd oci8-2.2.0
(3):运行一下命令:
phpize
运行的时候可能会出现一下错误:Can't find PHP headers in /usr/include/php The php-devel package is required for use
解决方案
yum install php72w-devel #注意一下,这条命令取决你安装的PHP版本,我这个命令并不适用所有人
(4):使用$ORACLE_HOME或Instant Client配置软件包
./configure --with-oci8=shared,instantclient,/usr/lib/oracle//client/lib
或
./configure -with-oci8=shared,$ORACLE_HOME
(5):执行编译安装:
make install
这里可能会报错:
make: *** No rule to make target build', needed by default'. Stop.
解决方案:
1:安装如下配置:
yum -y install make zlib-devel gcc-c++ libtool openssl openssl-devel
2: 重新 configure
./configure
3: 编译
make && make install
(6):配置php.ini
我们在PHP的配置文件php.ini中加上
extension=oci8.so
重启PHP
systemctl restart php-fpm
重启web服务器(nginx、apache等)。
systemctl restart nginx
以上就是php7.2怎么连接oracle数据库?OCI8扩展的安装的详细内容
免费试用尝鲜
贴心会员服务
服务可用性
数据安全保障
全年不间断在线
工作时间:早上9:00-下午6:30
河南快米云网络科技有限公司
公安备案编号:41010302002363
Copyright © 2010-2023 All Rights Reserved. 地址:河南自由贸易区开封片区经济开发区宋城路122号