>백엔드 개발 >PHP 튜토리얼 >Oracle 저장 프로시저에 대한 PHP 액세스에 대한 자세한 설명

Oracle 저장 프로시저에 대한 PHP 액세스에 대한 자세한 설명

怪我咯
怪我咯원래의
2017-07-10 12:01:191671검색

이 글에서는 주로 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;

패키지 이름은 PKG_TRANS_REL이고 저장 프로시저는 pro_GC_withdraw입니다. 두 가지 출력 매개변수.

PHP에서 pdo를 통해 호출하는 예:


  $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유형인 경우에는 지정해야 합니다

입력 매개변수값 전달 비교적 간단하지만 매개변수 추출은 조금 더 복잡하므로 길이를 지정해야 합니다

.

php 프로그램은 저장 프로시저를 사용하여 데이터베이스에 액세스할 수 있습니다. 어떤 사람들은 저장 프로시저를 사용하는 것이 유지 관리하기 더 쉽다고 생각합니다. 하지만 이 문제에 대해서는 선량한 사람들의 의견이 다릅니다. 저장 프로시저를 사용한다는 것은 DBA와 개발자가 더 긴밀하게 협력해야 한다는 의미이며, 둘 중 하나가 변경되면 분명히 유지 관리가 어려울 것이라고 생각합니다.

그러나 저장 프로시저를 사용하면 속도와 효율성이라는 두 가지 이상의 가장 확실한 이점이 있습니다. 저장 프로시저를 사용하는 것이 확실히 더 빠릅니다. 효율성 측면에서 애플리케이션이 일련의 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 code  

<?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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.