PHP调用Oracle存储过程的实操

数据库 Oracle
我们今天主要和大家分享的是何用PHP来调用Oracle存储过程的实际操作步骤,以及在运行中,我们所涉及到的代码的相关运用。

以下的文章主要是介绍如何用PHP来调用Oracle存储过程,以及在用PHP来调用Oracle存储过程的是实际应用代码的示例,以下就是文章的相关内容的主要秒素,望你在浏览之后,会有所收获。

建立一个test表

  1. create table test (  
  2. id number(16) not null,  
  3. name varchar2(30) not null,  
  4. primary key (id)  
  5. ); 

插入一条数据

 

  1. insert into test values (5, ’php_book’); 

建立一个Oracle存储过程

 

  1. create or replace procedure proc_test (  
  2. p_id in out number,  
  3. p_name out varchar2  
  4. ) as  
  5. begin  
  6. select name into p_name  
  7. from test  
  8. where id = 5;  
  9. end proc_test;  

php代码:

 

  1. <?php 

建立数据库连接

 

  1. $user = "scott"

数据库用户名

  1. $password = "tiger";  

密码

  1. $conn_str = "tnsname"

 连接串 

  1. (cstr : connection_string)  
  2. $remote = true  

是否远程连接
 

  1. if ($remote) {  
  2. $conn = ocilogon($user, $password, $conn_str);  
  3. }  
  4. else {  
  5. $conn = ocilogon($user, $password);  

设定绑定

  1. $id = 5

准备用以绑定的php变量 id

  1. $name = "";  

准备用以绑定的php变量 name

/** 调用Oracle存储过程的sql语句(sql_sp : sql_storeprocedure)

* 语法:

* begin 存储过程名([[:]参数]); end;

* 加上冒号表示该参数是一个位置

 

  1. **/  
  2. $sql_sp = "begin proc_test(:id, :name); end;";  
  3. parse  
  4. $stmt = ociparse($conn, $sql_sp);  
  5.  

执行绑定

  1. ocibindbyname($stmt, ":id", $id, 16);  

参数说明:绑定php变量$id到位置:id,并设定绑定长度16位

  1. ocibindbyname($stmt, ":name", $name, 30); 

execute

  1. ociexecute($stmt); 

结果

  1. echo "name is : $name<br>";  
  2. ?> 

上述的相关内容就是对用PHP来调用Oracle存储过程的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. Oracle存储过程中不存在返回值的缘由
  2. 实现Oracle存储过程的实际应用的代码
  3. Oracle存储过程中应注意的事项
  4. 深入高性能的Oracle动态SQL开发
  5. Oracle字段的转字符串实际操作方案

 

责任编辑:佚名 来源: 互联网
相关推荐

2010-04-16 11:22:08

Oracle存储过程

2010-04-16 12:58:48

Oracle sql

2010-04-15 17:45:26

Oracle存储过程

2010-05-05 14:55:15

Oracle存储过程

2010-04-30 09:34:24

Oracle多条件查询

2010-04-09 09:07:43

Oracle游标触发器

2010-04-12 09:36:29

Oacle merge

2009-01-19 08:59:04

PHP调用MySQL存储过程MySQLi扩展

2010-04-15 14:18:30

Oracle创建

2010-05-10 17:00:53

Oracle死锁进程

2010-04-09 10:13:13

Oracle数据字典

2010-10-29 16:12:51

Oracle存储过程

2010-04-20 13:17:44

2010-04-30 11:29:19

Oracle Data

2010-04-20 16:24:52

Oracle EM

2010-04-16 17:35:39

Oracle进程

2010-04-19 17:39:04

Oracle导入

2010-04-13 16:30:13

Oracle权限

2017-09-04 11:48:56

MybatisOracle存储过程

2010-04-27 10:25:28

Oracle Subs
点赞
收藏

51CTO技术栈公众号