一、安装oracle客户端
官网网址:http://www.oracle.com/technetwork/topics/intel-macsoft-096467.html
instantclient-basic-macos.x64-12.2.0.1.0-2.zip、
instantclient-sdk-macos.x64-12.2.0.1.0-2.zip 、
instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip(这个是用来独立连接数据库,可以不下载)
下载后把这三个包里的内容都解压放到一个目录下,假设是/usr/local/instantclient
,然后建立几个符号链接,之后的编译和最后生成的oci8.so文件会用到:
ln -s /usr/local/instantclient/libclntsh.dylib.12.1 /usr/local/instantclient/libclntsh.dylib
ln -s /usr/local/instantclient/libclntsh.dylib.12.1 /usr/local/lib/
ln -s /usr/local/instantclient/libnnz12.dylib /usr/local/lib/
ln -s /usr/local/instantclient/libocci.dylib.12.1 /usr/local/lib/
ln -s /usr/local/instantclient/libociei.dylib /usr/local/lib/
注意:其中第一个符号链接如果不建立,编译的时候会出错。中间两个符号链接如果不建立,oci8.so会加载失败,提示找不到对应的dylib文件。后面两个符号链接如果不建立,今后在执行PHP的过程中oci_connect()函数会抛异常。如果今后依然遇到其他失败的信息,则以此类推,将instantclient目录下的dylib文件都在/usr/local/lib下建立符号链接即可。如果想简单粗暴一些,那也可以把instantclient下的dylib文件都拷贝到/usr/local/lib下二、pecl快捷安装oci8
sudo pecl install oci8
在提示输入instantclient目录位置的地方,输入instantclient,/usr/local/instantclient
根据提示,在/usr/local/etc/php/7.1/conf.d/
目录下手工建一个ext-oci8.ini
文件。如果没有conf.d这个文件夹则手动创建
cd /usr/local/etc/php/7.1
mkdir -p conf.d
cd conf.d
cat > ext-oci8.ini
[oci8]
extension="/usr/local/Cellar/php71/7.1.13_24/lib/php/extensions/debug-non-zts-20160303/oci8.so"
然后在php7.1的配置文件php.ini(/usr/local/etc/php/7.1/php.ini)里面添加扩展
extension=oci8.so;
然后,php -m 能看到oci扩展,但是<? echo phpinfo(); ?> 还是看不到,通过php-fpm.restart重启php-fpm就可以了,因为我之前brew安装了php7.0,后来brew又安装php7.1的。之前安装php7.0在~/.bash_aliases里配置的php-fpm的start、stop、restart是针对php7.0的,现在要给php7.1的也添加一个php-fpm的3种命令切换
vim ~/.bash_aliases
#让快捷命令生效
echo "[[ -f ~/.bash_aliases ]] && . ~/.bash_aliases" >> ~/.bash_profile
source ~/.bash_profile
然后再到phpinfo对应页面里,就可以看到oci8扩展了
三、连接oracle数据库并使用
$conn = oci_connect('账号', '密码', "(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=连接oracle的ip地址)(PORT = 端口号))(CONNECT_DATA =(SID=HCMPRD2)))", "utf8");
$query = oci_parse($conn, "select * from TEST.ABC");//TEST数据库的ABC表
oci_execute($query);
oci_fetch_all($query, $list, null, null, OCI_FETCHSTATEMENT_BY_ROW);
var_dump($list);
https://segmentfault.com/a/1190000008224468http://blog.sina.com.cn/s/blog_6d85b84b0102wwhr.html
http://blog.youkuaiyun.com/qq_15574035/article/details/76619751