




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
何在PHP中使用Oracle数据库在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地址如() 还需要一个游标 Ora_Open. 该游标常常用来枚举数据。我们用 Ora_Parse 或 Ora_Exec 查询Oracle的结果集. Ora_Parse 效验SQL语法正确性 而 Ora_Exec 则执行相应的SQL语句. 如果这一切都正常运行,那么我们就运行 Ora_Commit来确认. Create A Table Using OCI 下面我们将建立一个email个人信息簿。这次采用OCI8 API指令 相关PHP代码: PutEnv(ORACLE_SID=ORASID); $connection = OCILOGOn (username, password); if ($connection = false) echo OCIError($connection). ; exit; $query = create table email_info . (fullname varchar(255), email_address varchar(255); $cursor = OCIParse ($connection, $query); if ($cursor = false) echo OCIError($cursor). ; exit; $result = OCIExecute ($cursor); if ($result = false) echo OCIError($cursor). ; exit; OCICommit ($connection); OCILOGOff ($connection); ? 我们可以看到这2段代码语法几乎都一样,区别仅仅函数名字不同; 其次,在OCI8中我们不需要专门运行打开游标的指令,在调用 OCIParse 系统就自动返回了一个游标ID. 利用 ORA 向数据表 email_info 输入数据 当用户浏览这段脚本时,显示一个由姓名、email输入域组成的表单;当用户添好数据点击提交时,脚本程序将把这姓名、email保存到email_info数据表中。 相关PHP代码: if ($submit = click) / The submit button was clicked! / Get the input for fullname and email then store it in the database. 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 = insert into email_info values ($fullname, $email); $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); else echo FORM action=insert.PHP method=post 请输入姓名 INPUT name=fullname/INPUT 请输入Email地址 INPUT name=email/INPUT INPUT name=submit type=submit value=click/INPUT /FORM ; ? 利用OCI向数据表 email_info 输入数据 同上,只不过用OCI来写 相关PHP代码: if ($submit = click) / The submit button was clicked! / Get the input for fullname and email then store it in the database. PutEnv(ORACLE_SID=ORASID); $connection = OCILOGOn (username,password); if ($connection = false) echo OCIError($connection). ; exit; $query = insert into email_info values ($fullname, $email); $cursor = OCIParse ($connection, $query); if ($cursor = false) echo OCIError($cursor). ; exit; $result = OCIExecute ($cursor); if ($result = false) echo OCIError($cursor). ; exit; OCICommit ($connection); OCILOGOff ($connection); else echo FORM action=insert.PHP method=post 请输入姓名 INPUT name=fullname/INPUT 请输入 Email 地址 INPUT name=email/INPUT INPUT name=submit type=submit value=click/INPUT /FORM ; ? 对了,这段脚本必须存为insert.PHP,因为在调用的页面中指定insert.PHP为表单处理程序利用ORA列出全部数据表email_info中的数据 下面,我们将逐条读出数据库的内容,并以HTML表格形式显示email_info数据表中的数据 相关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 = select * from email_info; $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; echo ; echo Full Name Email Address ; while (Ora_Fetch_Into ($cursor, &$values) $name = $values0; $email = $values1; echo $name $email ; echo ; Ora_Close ($cursor); Ora_LOGOff ($connection); ? 程序运行的浏览效果如下所示: 姓名 Email 地址 春花 秋月 . . 利用OCI列出全部数据表email_info中的数据 同上,只不过用OCI来写 相关PHP代码: PutEnv(ORACLE_SID=ORASID); $connection = OCILOGOn (username,password); if ($connection = false) echo OCIError($connection). ; exit; $query = select * from email_info; $cursor = OCIParse ($connection, $query); if ($cursor = false) echo OCIError($cursor). ; exit; $result = OCIExecute ($cursor); if ($result = false) echo OCIError($cursor). ; exit; echo ; echo Full Name Email Address
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030中国功能性啤酒产品创新趋势与市场接受度调研报告
- 房产抵押借款协议书范本5篇
- 2025-2026学年北京市八年级上学期期中模拟英语试题(含解析)
- 2025年江油市属事业单位考试试卷
- 2025江西赣州市第五人民医院劳务派遣招聘精神科助理医师1名考前自测高频考点模拟试题及答案详解(新)
- 2025年海洋能发电技术政策环境与法规解读报告
- 2025年海洋可再生能源:海水提碘吸附材料技术创新在海洋可再生能源开发中的应用
- 2025年湖南省郴州桂阳县龙潭街道城镇公益性岗位招聘考前自测高频考点模拟试题及答案详解(夺冠)
- 2025安康市交通运输局定向招聘残疾工作人员(2人)模拟试卷及答案详解(夺冠系列)
- 2025年温州永嘉县卫生健康系统公开招聘医学类工作人员25人模拟试卷及答案详解1套
- 创建文明班级班会课件
- 2025年新修订治安管理处罚法课件
- 社会渠道支撑管理制度
- DBJ50-T-047-2024 建筑地基基础设计标准
- 呼吸科出科小讲课
- 2025年中国红富士苹果市场深度调研研究报告
- 钢结构项目可行性研究报告(立项申请报告)模板
- 仓库员工考试题及答案
- 借车给他人免责协议书
- 中西医结合治疗冠心病
- 高校课堂教学创新大赛一等奖课件:创新教学模式在内科学教学中的实践
评论
0/150
提交评论