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 相关文章推荐
PHP 时间日期操作实战
Aug 26 PHP
php生成静态文件的多种方法分享
Jul 17 PHP
ThinkPHP中pathinfo的访问模式、路径访问模式及URL重写总结
Aug 23 PHP
php校验表单检测字段是否为空的方法
Mar 20 PHP
解析WordPress中函数钩子hook的作用及基本用法
Dec 22 PHP
CodeIgniter多语言实现方法详解
Jan 20 PHP
thinkphp框架下404页面设置 仅三步
May 14 PHP
PHP+MySql+jQuery实现的&quot;顶&quot;和&quot;踩&quot;投票功能
May 21 PHP
PHP加密解密类实例代码
Jul 20 PHP
PHP用正则匹配form表单中所有元素的类型和属性值实例代码
Feb 28 PHP
PHP实现新型冠状病毒疫情实时图的实例
Feb 04 PHP
Thinkphp 框架扩展之Widget扩展实现方法分析
Apr 23 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
PHP中的命名空间详细介绍
2015/07/02 PHP
ajax无刷新动态调用股票信息(改良版)
2008/11/01 Javascript
手把手教你自己写一个js表单验证框架的方法
2010/09/14 Javascript
简单的代码实现jquery定时器
2014/01/03 Javascript
js 动态修改css文件用到了cssRule
2014/08/20 Javascript
JavaScript知识点整理
2015/12/09 Javascript
详解JavaScript基于面向对象之继承
2015/12/13 Javascript
如何防止INPUT按回车自动提交表单FORM
2016/12/06 Javascript
AngularJS实现动态添加Option的方法
2017/05/17 Javascript
详谈JS中数组的迭代方法和归并方法
2017/08/11 Javascript
Node.js 的模块知识汇总
2017/08/16 Javascript
Vue Cli与BootStrap结合实现表格分页功能
2017/08/18 Javascript
vue.js默认路由不加载linkActiveClass问题的解决方法
2017/12/11 Javascript
js中innerText/textContent和innerHTML与target和currentTarget的区别
2019/01/21 Javascript
element form 校验数组每一项实例代码
2019/10/10 Javascript
Vue搭建后台系统需要注意的问题
2019/11/08 Javascript
vue配置多代理服务接口地址操作
2020/09/08 Javascript
Python实现获取某天是某个月中的第几周
2015/02/11 Python
python通过exifread模块获得图片exif信息的方法
2015/03/16 Python
基python实现多线程网页爬虫
2015/09/06 Python
python实现实时监控文件的方法
2016/08/26 Python
python用opencv批量截取图像指定区域的方法
2019/01/24 Python
简单了解django索引的相关知识
2019/07/17 Python
python安装virtualenv虚拟环境步骤图文详解
2019/09/18 Python
python pip安装包出现:Failed building wheel for xxx错误的解决
2019/12/25 Python
pygame用blit()实现动画效果的示例代码
2020/05/28 Python
python用什么编辑器进行项目开发
2020/06/17 Python
python爬取代理IP并进行有效的IP测试实现
2020/10/09 Python
李维斯牛仔裤英国官方网站:Levi’s英国
2019/10/10 全球购物
保卫科工作岗位职责
2014/03/01 职场文书
前台文员职责范本
2014/03/07 职场文书
农业局党的群众路线教育实践活动整改方案
2014/09/20 职场文书
邀请书模板
2015/02/02 职场文书
寒假社会实践个人总结
2015/03/06 职场文书
情感电台广播稿
2015/08/18 职场文书
Nginx访问日志及错误日志参数说明
2021/03/31 Servers