windwos下使用php连接oracle数据库的过程分享


Posted in PHP onMay 26, 2014

要使用php连接oracle,基本条件是
1.需要你安装了php、
2.安装了oracle、
3.配置了tnsname.ora。
本地命令行使用sqlplus能够连接到oracle。

根据你机器的版本选对64bit或者32bit的php程序,我们使用php的oci8扩展连接oracle

安装好php后,打开oci8扩展,

写一段连接oracle的ora.php代码

<?php
$conn = oci_connect('hr', 'welcome', 'MYDB');
if (!$conn) {
    $e = oci_error();
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}
// Prepare the statement
$stid = oci_parse($conn, 'SELECT * FROM departments');
if (!$stid) {
    $e = oci_error($conn);
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}
// Perform the logic of the query
$r = oci_execute($stid);
if (!$r) {
    $e = oci_error($stid);
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}
// Fetch the results of the query
print "<table border='1'>\n";
while ($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) {
    print "<tr>\n";
    foreach ($row as $item) {
        print "    <td>" . ($item !== null ? htmlentities($item, ENT_QUOTES) : " ") . "</td>\n";
    }
    print "</tr>\n";
}
print "</table>\n";
oci_free_statement($stid);
oci_close($conn);
?>

说明:
oci_connect('hr', 'welcome', 'MYDB')
第一个参数是oracle的用户名,
第二个参数是oracle的密码
第三个参数是tnsnames.ora里的连接串名

命令行下执行

php ora.php

提示如下错误

PHP Warning: PHP Startup: Unable to load dynamic library 'C:\php\php_oci8.dll'- %1 不是有效的 Win32 应用程序。 in Unknown on line 0
PHP Parse error: syntax error, unexpected '"user"' (T_CONSTANT_ENCAPSED_STRING) in C:\Users\nginx\Desktop\oraclephpoci\oci.php on line 3

开始以为是没有选对版本,我是64位的机器,结果说是win32的程序,一看字面提示,我就重新安装了新的32bit程序还是报错。

仔细查了查发现在32位像64位迁移的问题,出现如下问题时,我们需要安装Oracle Instant Client。

Unable to load dynamic library 'C:\Program Files (x86)\PHP\ext\php_oci8_11g.dll' - %1 is not a valid Win32 application.
Warning oci_connect(): OCIEnvNlsCreate() failed. There is something wrong with your system - please check that PATH includes the directory with Oracle Instant Client libraries

Oracle Instant Client,它是一个解压后就能使用的程序,不需要安装。
如果有oracle账号的可以去oracle下载对应的版本,(注册用户需要一堆信息)

http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html

嫌麻烦的同学使用这个地址下载

http://eduunix.ccut.edu.cn/index2/database/Oracle%20Instant%20Client/

下载后把压缩包解压到c:\oracleinstantclient,并添加路径到环境变量PATH

重新执行php ora.php,“%1 不是有效的 Win32 应用程序”的错误没有了,但是会提示

syntax error, unexpected T_CONSTANT_ENCAPSED_STRING

代码是从php官网直接拷过来的,代码中有不可见的字符,使用notepad++查看所有字符,去掉乱码即可。

继续执行,这次提示,

PHP Fatal error: ORA-12154: TNS:could not resolve the connect identifier specified in C:\Users\nginx\Desktop\airline\oci.php on line 6

看样子是php没有找到tnsnames.ora的位置,时间比较赶,那我就直接使用ip的形式,具体格式根据你的信息拼写oci_connect的第三个参数
oracle10格式:[//]host_name[:port][/service_name]
oracle11格式:[//]host_name[:port][/service_name][:server_type][/instance_name].
我具体使用的php oci连接串是:
$conn = oci_connect('hr', 'welcome', '//3water.com:1523/sycx');

配好上述信息后,终于能出结果了,但是发现查出来的结果中问乱码,这种问题基本都是编码不匹配。

php oci8中文乱码解决办法,先查询你的oracle的数据库编码使用,

select userenv('language') from dual;

查出来的结果是SIMPLIFIED CHINESE_CHINA.ZHS16GBK,在php的代码里设置环境变量
putenv("NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK");

终于php能够正确连接到oracle啦。

PHP 相关文章推荐
利用 window_onload 实现select默认选择
Oct 09 PHP
php auth_http类库进行身份效验
Mar 19 PHP
codeigniter使用技巧批量插入数据实例方法分享
Dec 31 PHP
PHP生成二维码的两个方法和实例
Jul 01 PHP
php可应用于面包屑导航的迭代寻找家谱树实现方法
Feb 02 PHP
php多次include后导致全局变量global失效的解决方法
Feb 28 PHP
php版阿里大于(阿里大鱼)短信发送实例详解
Nov 30 PHP
php实现留言板功能(代码详解)
Mar 28 PHP
PHP快速推送微信模板消息
Apr 14 PHP
PHP递归实现汉诺塔问题的方法示例
Nov 25 PHP
解决php extension 加载顺序问题
Aug 16 PHP
PHP网站常见安全漏洞,及相应防范措施总结
Mar 01 PHP
查找php配置文件php.ini所在路径的二种方法
May 26 #PHP
php5.2以下版本无json_decode函数的解决方法
May 25 #PHP
模板引擎smarty工作原理以及使用示例
May 25 #PHP
浅析php中json_encode()和json_decode()
May 25 #PHP
浅析PHP微信支付通知的处理方式
May 25 #PHP
PHP开发微信支付的代码分享
May 25 #PHP
php定时计划任务与fsockopen持续进程实例
May 23 #PHP
You might like
PHP3 safe_mode 失效漏洞
2006/10/09 PHP
CI框架入门之MVC简单示例
2016/11/21 PHP
PHP变量的作用范围实例讲解
2020/12/22 PHP
prototype 的说明 js类
2006/09/07 Javascript
javascript 面向对象全新理练之继承与多态
2009/12/03 Javascript
javascript中的对象创建 实例附注释
2011/02/08 Javascript
原生js实现跨浏览器获取鼠标按键的值
2013/04/08 Javascript
div模拟选择框示例代码
2013/11/03 Javascript
jquery 实现两Select 标签项互调示例代码
2014/09/25 Javascript
JavaScript中的对象的extensible属性介绍
2014/12/30 Javascript
jQuery使用$.each遍历json数组的简单实现方法
2016/04/18 Javascript
Svg.js实例教程及使用手册详解(一)
2016/05/16 Javascript
通过AngularJS实现图片上传及缩略图展示示例
2017/01/03 Javascript
Nodejs高扩展性的模板引擎 functmpl简介
2017/02/13 NodeJs
ztree简介_动力节点Java学院整理
2017/07/19 Javascript
浅谈在vue中用webpack打包之后运行文件的问题以及相关配置方法
2018/02/21 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
详解angular如何调用HTML字符串的方法
2018/06/30 Javascript
Vue.js 利用v-for中的index值实现隔行变色
2018/08/01 Javascript
Electron vue的使用教程图文详解
2019/07/05 Javascript
解决vue项目router切换太慢问题
2020/07/19 Javascript
[00:36]DOTA2上海特级锦标赛 Alliance战队宣传片
2016/03/04 DOTA
python snownlp情感分析简易demo(分享)
2017/06/04 Python
Python排序算法之选择排序定义与用法示例
2018/04/29 Python
Django 拆分model和view的实现方法
2019/08/16 Python
Spring Cloud Feign高级应用实例详解
2019/12/10 Python
国外最大的眼镜网站:Coastal
2017/08/09 全球购物
美国室内和室外装饰花盆购物网站:ePlanters
2019/03/22 全球购物
AJAX的优缺点都有什么
2015/08/18 面试题
产品销售员岗位职责
2013/12/18 职场文书
《桃花心木》教学反思
2014/02/17 职场文书
抗洪救灾先进集体事迹材料
2014/05/26 职场文书
2015教师节师德演讲稿
2015/03/19 职场文书
2015年法律事务部工作总结
2015/07/27 职场文书
Nginx location 和 proxy_pass路径配置问题小结
2021/09/04 Servers
python实现手机推送 代码也就10行左右
2022/04/12 Python