이 글에서는 주로 php 접속 oracle 저장 프로시저상세 예시를 소개하고 있습니다. 이런 기능을 구현하는데 도움이 되는 예시 코드를 소개합니다.
php access oracle 저장 프로시저 자세한 예시를 참고해보세요.
예를 들어 내 로컬 Oracle 데이터베이스에는 저장 프로시저가 포함된 패키지가 있습니다.create or replace package PKG_TRANS_REL is -- Author : test -- Created : -- Purpose : test -- Public type declarations PKG_NAME varchar2(20) := 'PKG_TRANS_REL'; --存储过程,测试用 procedure pro_GC_withdraw(in_merch_no in varchar2, in_withdraw_amt in number, out_result out number, out_errmsg out varchar2); end PKG_TRANS_REL;
$this->_pdo = new PDO(PDO_DB_DNS, PDO_DB_USER, PDO_DB_PASSWORD); $call = "CALL PKG_TRANS_REL.pro_GC_withdraw(?,?,?,?)"; try{ $stmt = $this->_pdo->prepare($call); $stmt->bindParam(1, $merch_no); $stmt->bindParam(2, $amount, PDO::PARAM_INT); $stmt->bindParam(3, $result, PDO::PARAM_INT, 4); $stmt->bindParam(4, $error_msg, PDO::PARAM_STR, 64); $stmt->execute(); }catch (PDOException $e) { $msg = 'SQL:'.$e->getMessage(); $msg = iconv('GBK','UTF-8',$msg); user_dump('SQL:'.$msg); return false; } ...bindParam 세 번째 매개변수의 기본값은 PDO::PARAM_STR입니다. other유형인 경우에는 지정해야 합니다
입력 매개변수값 전달 비교적 간단하지만 매개변수 추출은 조금 더 복잡하므로 길이를 지정해야 합니다
. 그러나 저장 프로시저를 사용하면 속도와 효율성이라는 두 가지 이상의 가장 확실한 이점이 있습니다. 저장 프로시저를 사용하는 것이 확실히 더 빠릅니다. 효율성 측면에서 애플리케이션이 일련의 SQL 작업을 한 번에 수행해야 하는 경우 PHP와 Oracle을 오가며 왕복 횟수를 줄이기 위해 애플리케이션을 데이터베이스에 직접 배치하는 것이 좋습니다. 그리고 효율성을 높이세요. 하지만 인터넷 응용 프로그램에서는 속도가 매우 중요하므로 저장 프로시저를 사용해야 합니다. 저도 얼마 전에는 PHP를 사용하여 저장 프로시저를 호출하고 다음 예제를 수행했습니다. code//建立一个test表 create table test ( id number(16) not null, name varchar2(30) not null, primary key (id) ); //插入一条数据 insert into test values (5, 'php_book'); //建立一个存储过程 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;
<?php //建立数据库连接 $user = "scott"; //数据库用户名 $password = "tiger"; //密码 $conn_str = "tnsname"; //连接串(cstr : connection_string) $remote = true //是否远程连接 if ($remote) { $conn = ocilogon($user, $password, $conn_str); } else { $conn = ocilogon($user, $password); } //设定绑定 $id = 5; //准备用以绑定的php变量 id $name = ""; //准备用以绑定的php变量 name /** 调用存储过程的sql语句(sql_sp : sql_storeprocedure) * 语法: * begin 存储过程名([[:]参数]); end; * 加上冒号表示该参数是一个位置 **/ $sql_sp = "begin proc_test(:id, :name); end;"; //parse $stmt = ociparse($conn, $sql_sp); //执行绑定 ocibindbyname($stmt, ":id", $id, 16); //参数说明:绑定php变量$id到位置:id,并设定绑定长度16位 ocibindbyname($stmt, ":name", $name, 30); //execute ociexecute($stmt); //结果 echo "name is : $name<br>"; ?>
위 내용은 Oracle 저장 프로시저에 대한 PHP 액세스에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!