PHP调用Oracle存储过程的实操

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

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

建立一个test表

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

插入一条数据

 

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

建立一个Oracle存储过程

 

create or replace procedure proc_test (  
p_id in out number,  
p_name out varchar2  
) as  
begin  
select name into p_name  
from test  
where id = 5;  
end proc_test;  

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

php代码:

 

<?php 
  • 1.

建立数据库连接

 

$user = "scott"
  • 1.

数据库用户名

$password = "tiger";  
  • 1.

密码

$conn_str = "tnsname"
  • 1.

 连接串 

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

是否远程连接
 

if ($remote) {  
$conn = ocilogon($user, $password, $conn_str);  
}  
else {  
$conn = ocilogon($user, $password);  

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

设定绑定

$id = 5
  • 1.

准备用以绑定的php变量 id

$name = "";  
  • 1.

准备用以绑定的php变量 name

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

* 语法:

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

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

 

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

执行绑定

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

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

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

execute

ociexecute($stmt); 
  • 1.

结果

echo "name is : $name<br>";  
?> 
  • 1.
  • 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-04-30 09:34:24

Oracle多条件查询

2010-05-05 14:55:15

Oracle存储过程

2010-04-12 09:36:29

Oacle merge

2010-04-09 09:07:43

Oracle游标触发器

2010-04-15 14:18:30

Oracle创建

2010-04-09 10:13:13

Oracle数据字典

2010-05-10 17:00:53

Oracle死锁进程

2009-01-19 08:59:04

PHP调用MySQL存储过程MySQLi扩展

2010-04-16 17:35:39

Oracle进程

2010-04-30 11:29:19

Oracle Data

2010-04-20 13:17:44

2010-04-19 17:39:04

Oracle导入

2010-04-13 16:30:13

Oracle权限

2010-04-20 16:24:52

Oracle EM

2017-09-04 11:48:56

MybatisOracle存储过程

2010-10-29 16:12:51

Oracle存储过程

2010-04-13 14:00:00

Oracle inse
点赞
收藏

51CTO技术栈公众号