龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

PHP调用Oracle存储过程的实操

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
以下的文章主要是介绍如何用PHP来调用 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存储过程的描述,希望会给你带来一些帮助在此方面。

精彩图集

赞助商链接