如何在PHP中使用Oracle数据库(1)


Posted in PHP onOctober 09, 2006

在php3.0以上版本中,php内置了几乎目前所有的数据库处理函数,包括Oracle;在本文中我们通过一个实例来介绍了如何使用这些函数来操作Oracle数据库。  

PHP提供了2大类API(应用程序接口)来操作Oracle数据库。一个是标准的Oracle处理函数(ORA) 另一个是Oracle 8调用接口函数(OCI8). 后者只能在Oracle 7或8版本上使用。 由于OCI8 提供了很多优化选项,因此只要有可能就应该采用 OCI8 接口。这里我们分别用这二种函数集进行了演示。  

首先本文的前提假设你已经装好了 Oracle数据库环境 和 PHP 开发环境.  如果不懂也没多大关系,网上有很多相关的好文章可以参考。

第一步:创建 一个实验用的数据库

这个问题你可以请你的数据库管理员或参考Oracle用户手册处理,这里不再多讲  

用 ORA 建立数据表

即使你已经创建好了数据表,也请看看本段文字。它可以告诉你如何用PHP+SQL的技术操作Oracle

在本例中我们创建了一个用于存放个人email的数据表

相关PHP代码:

PutEnv("ORACLE_SID=ORASID");

$connection = Ora_Logon ("username", "password");
if ($connection == false){
  echo Ora_ErrorCode($connection).": ".Ora_Error($connection)."
";
  exit;
}    

$cursor = Ora_Open ($connection);
if ($cursor == false){
  echo Ora_ErrorCode($connection).": ".Ora_Error($connection)."
";
  exit;
}    

$query = "create table email_info " .
       "(fullname varchar(255), email_address varchar(255))";

$result = Ora_Parse ($cursor, $query);
if ($result == false){
  echo Ora_ErrorCode($cursor).": ".Ora_Error($cursor)."
";
  exit;  
}

$result = Ora_Exec ($cursor);
if ($result == false){
  echo Ora_ErrorCode($cursor).": ".Ora_Error($cursor)."
";
  exit;  
}

Ora_Commit ($connection);
Ora_Close ($cursor);
Ora_Logoff ($connection);

?>  

为了处理Oracle数据库,我们首先要和Oracle建立一个联结。
语法是 Ora_Logon (user, password),返回一个connectID..   
提醒: 在此之前我们还必须设置环境变量: ORACLE_SID的值.  

现在,我们可以通过该联结的 ID对Oracle进行交互式操作了。数据表名字就叫email_info吧。该表由2个域组成,一个存储个人全名,(如:晓月)一个存储email地址如(xiaoyue@163.net)  

还需要一个游标 Ora_Open.  该游标常常用来枚举数据。我们用 Ora_Parse 或 Ora_Exec 查询Oracle的结果集.  Ora_Parse 效验SQL语法正确性 而 Ora_Exec 则执行相应的SQL语句.  如果这一切都正常运行,那么我们就运行 Ora_Commit来确认. 

PHP 相关文章推荐
php htmlentities和htmlspecialchars 的区别
Aug 18 PHP
基于xcache的配置与使用详解
Jun 18 PHP
phpstrom使用xdebug配置方法
Dec 17 PHP
将酷狗krc歌词解析并转换为lrc歌词php源码
Jun 20 PHP
php事务处理实例详解
Jul 11 PHP
PHP SPL标准库之SplFixedArray使用实例
May 12 PHP
Linux系统下PHP-FPM的安装和配置教程
Aug 17 PHP
[原创]php使用curl判断网页404(不存在)的方法
Jun 23 PHP
Yii输入正确验证码却验证失败的解决方法
Jun 06 PHP
PHP操作路由器实现方法示例
Apr 27 PHP
PHP中->和=>的含义及使用示例解析
Aug 06 PHP
win10下 php安装seaslog扩展的详细步骤
Dec 04 PHP
BBS(php & mysql)完整版(八)
Oct 09 #PHP
超级简单的发送邮件程序
Oct 09 #PHP
发挥语言的威力--融合PHP与ASP
Oct 09 #PHP
如何在PHP中使用Oracle数据库(2)
Oct 09 #PHP
用PHP连接Oracle for NT 远程数据库
Oct 09 #PHP
BBS(php & mysql)完整版(六)
Oct 09 #PHP
用PHP4访问Oracle815
Oct 09 #PHP
You might like
打造计数器DIY三步曲(下)
2006/10/09 PHP
PHP基于单例模式实现的mysql类
2016/01/09 PHP
PHP中的随机性 你觉得自己幸运吗?
2016/01/22 PHP
php中str_pad()函数用法分析
2017/03/28 PHP
PHP基于自增数据如何生成不重复的随机数示例
2017/05/19 PHP
Docker 安装 PHP并与Nginx的部署实例讲解
2021/02/27 PHP
js类 from qq
2006/11/13 Javascript
JS跨域代码片段
2012/08/30 Javascript
js实现网页倒计时、网站已运行时间功能的代码3例
2014/04/14 Javascript
JS动态修改iframe高度和宽度的方法
2015/04/01 Javascript
Javascript数组循环遍历之forEach详解
2016/11/07 Javascript
使用JS代码实现点击按钮下载文件
2016/11/12 Javascript
jQuery Ajax前后端使用JSON进行交互示例
2017/03/17 Javascript
Javascript中将变量转换为字符串的三种方法
2017/09/19 Javascript
Webpack中publicPath路径问题详解
2018/05/03 Javascript
vue生命周期实例小结
2018/08/15 Javascript
JS/HTML5游戏常用算法之追踪算法实例详解
2018/12/12 Javascript
python 生成目录树及显示文件大小的代码
2009/07/23 Python
Python制作CSDN免积分下载器
2015/03/10 Python
Python 爬虫学习笔记之单线程爬虫
2016/09/21 Python
利用Python自带PIL库扩展图片大小给图片加文字描述的方法示例
2017/08/08 Python
浅谈python jieba分词模块的基本用法
2017/11/09 Python
python去除拼音声调字母,替换为字母的方法
2018/11/28 Python
python实现读取excel文件中所有sheet操作示例
2019/08/09 Python
Ubuntu16.04安装python3.6.5步骤详解
2020/01/10 Python
在pytorch 中计算精度、回归率、F1 score等指标的实例
2020/01/18 Python
皇家阿尔伯特瓷器美国官网:Royal Albert美国
2020/02/16 全球购物
养殖项目策划书范文
2014/01/13 职场文书
运动会宣传口号
2014/06/09 职场文书
委托书范本
2014/09/13 职场文书
2014年学校领导班子对照检查材料
2014/09/19 职场文书
民主生活会对照检查材料范文
2014/10/01 职场文书
小学体育队列队形教学反思
2016/02/16 职场文书
Java实现简易的分词器功能
2021/06/15 Java/Android
python 对图片进行简单的处理
2021/06/23 Python
SQL Server数据库查询出现阻塞之性能调优
2022/04/10 SQL Server