>  기사  >  백엔드 개발  >  PDO의 저장 프로시저에 대한 자세한 소개

PDO의 저장 프로시저에 대한 자세한 소개

黄舟
黄舟원래의
2017-04-28 17:47:493047검색

PDO의 저장 프로시저 상세 소개

PDO의 저장 프로시저를 사용하면 데이터를 데이터에 더 가깝게 조작할 수 있어 대역폭 사용량이 줄어들고, 데이터를 스크립트 로직과 독립적으로 서로 다른 언어를 사용하는 여러 시스템이 동일한 방식으로 데이터에 액세스할 수 있도록 하여 코딩 및 디버깅에 소요되는 귀중한 시간을 절약하는 동시에 미리 정의된 시나리오를 사용하여 작업을 수행하고 쿼리 속도를 높일 수 있습니다. 데이터를 보호하여 데이터를 보호합니다!

이전 글 "PDO의 트랜잭션 처리 상세 소개"에서 PDO의 트랜잭션 처리에 대해 소개했으니, 이번 글에서는 PDO의 저장 프로시저에 대해 소개하겠습니다!

먼저 PDO에서 저장 프로시저를 호출하는 방법을 설명하겠습니다. 여기서는 먼저 다음 SQL 문을 사용하여 저장 프로시저를 만듭니다.

drop procedure if exists pro_reg;
delimiter//
create procedure pro_reg(in nc varchar(80),in pwd varchar(80), in email varchar(80),in address varchar(50))
begin
insert into tb_reg(name,pwd,email,address)values(nc,pwd,email,address);
end;
//

"drop" 문은 기존 저장 프로시저 pro_reg를 삭제합니다. MySQL 서버에서.

"delimiter//"의 기능은 문의 끝을 "//"로 바꾸는 것입니다.

"in nc varchar(80)....in address varchar(50)"은 저장 프로시저에 전달될 매개변수를 나타냅니다.

"begin...end"는 저장 프로시저의 명령문 블록을 나타내며 해당 기능은 PHP 언어의 "{.....}"와 유사합니다.

저장 프로시저가 성공적으로 생성된 후 아래 저장 프로시저가 호출되어 사용자 등록 정보를 추가하는 단계는 다음과 같습니다.

index.php 파일을 생성합니다. 먼저 양식을 만들고 POST 메서드를 통해 이 페이지에 사용자 정보를 제출합니다. 그런 다음 이 페이지에서 PHP 스크립트를 작성하고 PDO를 통해 MySQL 데이터베이스에 연결하고 데이터베이스 인코딩 형식을 UTF-8로 설정하여 양식에 제출된 사용자 등록 정보를 가져옵니다. 그런 다음 call 문을 통해 저장 프로시저 pro_reg를 호출하여 데이터 테이블에 사용자 등록 정보를 추가합니다. 마지막으로 try...catch... 문 블록을 통해 오류 정보가 반환됩니다. 키 코드는 다음과 같습니다.

<form name="form1" action="4.php" method="post">
    用户昵称:<input type="text" name="nc"><br>
    密   码:<input type="password" name="password"><br>
    邮   箱:<input type="text" name="email"><br>
    <input type="submit" name="Submit" value="注册">
    <input type="submit" name="Submit" value="重写">
</form>
<?php
if($_POST["Submit"]){
header("Content-Type:text/html; charset=utf-8");    //设置页面的编码格式
$dbms = "mysql";                                  // 数据库的类型
$dbName ="php_cn";                                //使用的数据库名称
$user = "root";                                   //使用的数据库用户名
$pwd = "root";                                    //使用的数据库密码
$host = "localhost";                              //使用的主机名称
$dsn  = "$dbms:host=$host;dbname=$dbName";
try {
    $pdo = new PDO($dsn, $user, $pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $nc = $_POST[&#39;nc&#39;];
    $password = md5($_POST[&#39;password&#39;]);
    $email = $_POST[&#39;email&#39;];
    $query = "call pro_reg(&#39;$nc&#39;,&#39;$password&#39;,&#39;$email&#39;)";
    $res = $pdo->prepare($query);//准备查询语句
    if ($res->execute()) {
        echo "添加数据库成功";
    } else {
        echo "添加数据库失败";
    }
}catch (PDOException $e){
    echo "PDO Exception Caught";
    echo &#39;Error with the database:<br>&#39;;
    echo &#39;SQL Query;&#39;.$query;
    echo &#39;<pre class="brush:php;toolbar:false">&#39;;
    echo "Error:".$e -> getMessage()."<br>";
    echo "Code:".$e ->getCode()."<br>";
    echo "File:".$e ->getFile()."<br>";
    echo "Line:".$e ->getLine()."<br>";
    echo "Trace:".$e ->getTraceAsString()."<br>";
    echo  "
"; } }

결과는 다음과 같습니다.

PDO의 저장 프로시저에 대한 자세한 소개

가장 중요한 것은 저장 프로시저를 만든 다음 이를 저장 프로시저를 호출하는 것입니다. 절차는 친구가 직접 할 수 있어요~! ~

요약:

PDO 데이터베이스 추상화 계층은 여기까지입니다. 개요, 특성 및 설치부터 데이터베이스 추상화 계층인 PDO에 중점을 두었습니다. 다양한 데이터베이스에 연결하는 방법, SQL 문을 실행하는 방법, 결과 집합을 얻고 오류 처리를 수행하는 방법을 포함한 PDO 예제 응용 프로그램을 소개한 다음 PDO의 고급 응용 프로그램: 트랜잭션 및 저장 프로시저를 소개하며 각 부분은 다음과 같습니다. 이 장을 공부하면 친구들이 PDO 기술의 응용을 익힐 수 있다고 믿습니다. 그럼 다음 주제에서 만나요!

위 내용은 PDO의 저장 프로시저에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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