>백엔드 개발 >PHP 튜토리얼 >Oracle의 저장 프로시저를 호출하는 PHP에 대한 자세한 설명

Oracle의 저장 프로시저를 호출하는 PHP에 대한 자세한 설명

怪我咯
怪我咯원래의
2017-07-10 11:59:541913검색

php 프로그램은 저장 프로시저를 사용하여 데이터베이스에 액세스할 수 있습니다. 어떤 사람들은 저장 프로시저를 사용하는 것이 유지 관리하기 더 쉽다고 생각합니다. 하지만 이 문제에 대해서는 선량한 사람들의 의견이 다릅니다. 저장 프로시저를 사용한다는 것은 DBA와 개발자가 더 긴밀하게 협력해야 한다는 의미이며, 둘 중 하나가 변경되면 분명히 유지 관리가 어려울 것이라고 생각합니다. 그러나 저장 프로시저를 사용하면 속도와 효율성이라는 두 가지 이상의 가장 확실한 이점이 있습니다. 저장 프로시저를 사용하는 것이 확실히 더 빠릅니다. 효율성 측면에서 애플리케이션이 일련의 SQL 작업을 한 번에 수행해야 하는 경우 PHP와 Oracle을 오가며 왕복 횟수를 줄이기 위해 애플리케이션을 데이터베이스에 직접 배치하는 것이 좋습니다. 그리고 효율성을 높이세요. 하지만 인터넷 응용 프로그램에서는 속도가 매우 중요하므로 저장 프로시저를 사용해야 합니다. 저도 얼마 전에는 PHP를 사용하여 저장 프로시저를 호출하고 다음 예제를 수행했습니다.

//建立一个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 코드

:

<?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으로 문의하세요.