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

mysql 저장 프로시저에 대한 자세한 설명과 PHP에서 MYSQL 저장 프로시저를 호출하는 예

不言
풀어 주다: 2023-03-25 17:32:02
원래의
1606명이 탐색했습니다.

이 글은 주로 mysql 저장 프로시저에 대한 자세한 설명과 PHP가 MYSQL 저장 프로시저를 호출하는 예제를 소개합니다. 이제는 필요한 친구들이 참고할 수 있도록 공유하겠습니다.

of mysql Stored Procedure
1.

过 저장 프로시저 소개

일반적으로 사용되는 작업 데이터베이스 언어인 SQL 문을 먼저 컴파일한 다음

Stored Procedure

를 실행해야 합니다. 특정 기능을 완료하기 위한 SQL 명령문 집합입니다. 사용자가 저장 프로시저의 이름을 지정하고 매개 변수(저장 프로시저에 매개 변수가 있는 경우)를 지정하여 호출하고 실행합니다. 그것. 저장 프로시저는 데이터베이스에 생성되고 저장되는 프로그래밍 가능한 함수입니다. SQL 문과 일부 특수 제어 구조로 구성될 수 있습니다. 저장 프로시저는 다양한 애플리케이션이나 플랫폼에서 동일한 기능을 수행하거나 특정 기능을 캡슐화하려는 경우에 유용합니다. 데이터베이스의 저장 프로시저는 프로그래밍의 객체 지향 접근 방식을 시뮬레이션한 것으로 볼 수 있습니다. 이를 통해 데이터에 액세스하는 방법을 제어할 수 있습니다.

저장 프로시저에는 일반적으로 다음과 같은 장점이 있습니다.

(1)

저장 프로시저는 SQL

언어의 기능과 유연성을 향상시킵니다. 저장 프로시저는 흐름 제어 문을 사용하여 작성할 수 있고 유연성이 뛰어나며 복잡한 판단과 더 복잡한 작업을 완료할 수 있습니다.

(2).저장 프로시저를 사용하면 표준 구성 요소를 프로그래밍할 수 있습니다. 저장 프로시저가 생성된 후에는 저장 프로시저의 SQL

문을 다시 작성할 필요 없이 프로그램에서 여러 번 호출할 수 있습니다. 그리고 데이터베이스 전문가는 애플리케이션 소스 코드에 영향을 주지 않고 언제든지 저장 프로시저를 수정할 수 있습니다.

(3).저장 프로시저를 사용하면 실행 속도가 더 빨라질 수 있습니다. 작업에 많은 양의 Transaction-SQL 코드가 포함되어 있거나 여러 번 실행되는 경우 저장 프로시저가 일괄 처리보다 훨씬 빠르게 실행됩니다. 저장 프로시저가 미리 컴파일되어 있기 때문입니다. 저장 프로시저가 처음 실행되면 최적화 프로그램이 쿼리를 분석하고 최적화하며 최종적으로 실행 계획이 시스템 테이블에 저장됩니다. 일괄 처리된 Transaction-SQL 문은 실행될 때마다 컴파일하고 최적화해야 하며 속도가 상대적으로 느립니다.

(4).저장 프로시저를 사용하면 네트워크 트래픽을 크게 줄일 수 있습니다. 동일한 데이터베이스 개체에 대한 작업(예: 쿼리, 수정)의 경우 이 작업과 관련된 Transaction-SQL 문이 저장 프로시저로 구성되면 클라이언트 컴퓨터에서 저장 프로시저가 호출될 때 해당 호출문만 네트워크를 통해 전송되므로 네트워크 트래픽이 크게 증가하고 네트워크 부하가 줄어듭니다.

(5).저장 프로시저를 보안 메커니즘으로 완벽하게 활용할 수 있습니다. 시스템 관리자는 특정 저장 프로시저의 실행 권한을 제한함으로써 해당 데이터에 대한 접근 권한을 제한하고, 승인되지 않은 사용자가 데이터에 접근하는 것을 방지하며 데이터의 보안을 확보할 수 있습니다.

2. MySQL 정보 저장 프로시저

저장 프로시저는 데이터베이스 저장의 중요한 기능입니다.

MySQL 저장 프로시저 5.0 이전에는 지원되지 않았으며 이로 인해 MySQL의 응용 프로그램이 크게 줄었습니다. 다행히 MySQL 5.0에서 마침내 저장 프로시저를 지원하기 시작했습니다. 이를 통해 데이터베이스 처리 속도가 크게 향상되고 데이터베이스 프로그래밍의 유연성도 향상될 수 있습니다.

3. MySQL저장 프로시저 생성

(1). 형식

MySQL저장 프로시저에 의해 생성된 형식: CREATE PROCEDURE 프로세스 이름([프로세스 매개변수[,...]])
[
특성...]프로세스 본문

여기 먼저 예를 들어보겠습니다:

  1. mysql> DELIMITER //  
    mysql> CREATE PROCEDURE proc1(OUT s int)  
        -> BEGIN
        -> SELECT COUNT(*) INTO s FROM user;  
        -> END
        -> //  
    mysql> DELIMITER ;
    로그인 후 복사

참고:

(1 ) 여기서 주목해야 할 것은 DELIMITER / /el 및 delimiter; , delimiter는 구분 기호를 의미합니다. 저장 프로시저는 SQL 문으로 처리되며 저장 프로시저의 컴파일 과정에서 오류가 보고되므로 DELIMITER 키워드를 사용하여 현재 세그먼트 구분 기호를 미리 선언해야 합니다. MySQL ";" 저장 프로시저에서 코드로 처리됩니다. 이러한 코드는 사용 후에는 실행되지 않습니다.

(2) 저장 프로시저에는 필요에 따라 입력, 출력, 입력 및 출력 매개 변수가 있을 수 있습니다. 여기에 출력 매개 변수 s가 있으며, 해당하는 경우 유형은 int 유형입니다. 여러 매개변수를 구분하려면 ","을 사용하세요.

(3) 프로세스 본문의 시작과 끝은 BEGINEND으로 표시됩니다.

이렇게 하면 MySQL 저장 프로시저 중 하나가 완성됩니다. 아주 쉽지 않나요?이해하지 못하더라도 상관없습니다. 자세히 설명할 것입니다.

(2). 선언 구분 기호

사실 선언 구분 기호에 관해 위의 설명은 매우 명확하므로 더 말할 필요도 없고 조금만 주의하면 됩니다. : MySQLAdministrator 관리 도구를 사용하는 경우 직접 생성할 수 있어 더 이상 선언할 필요가 없습니다.

(3).Parameters

MySQL 저장 프로시저의 매개 변수는 IN, IN, 세 가지 매개 변수 유형이 있습니다. OUT, INOUT ,다음과 같은 형식:

CREATE PROCEDURE([[IN |OUT |INOUT ] 매개변수 이름 데이터 유형...])

IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值

OUT 输出参数:该值可在存储过程内部被改变,并可返回

INOUT 输入输出参数:调用时指定,并且可被改变和返回

. IN参数例子

创建:

  1. mysql > DELIMITER //  
    mysql > CREATE PROCEDURE demo_in_parameter(IN p_in int)  
    -> BEGIN
    -> SELECT p_in;   
    -> SET p_in=2;   
    -> SELECT p_in;   
    -> END;   
    -> //  
    mysql > DELIMITER ;
    로그인 후 복사

执行结果:

  1. mysql > SET @p_in=1;  
    mysql > CALL demo_in_parameter(@p_in);  
    +------+ 
    | p_in |  
    +------+ 
    |   1  |   
    +------+ 
    +------+ 
    | p_in |  
    +------+ 
    |   2  |   
    +------+ 
    mysql> SELECT @p_in;  
    +-------+ 
    | @p_in |  
    +-------+ 
    |  1    |  
    +-------+
    로그인 후 복사

以上可以看出,p_in虽然在存储过程中被修改,但并不影响@p_id的值

.OUT参数例子

创建:

mysql > DELIMITER //  
mysql > CREATE PROCEDURE demo_out_parameter(OUT p_out int)  
-> BEGIN
-> SELECT p_out;  
-> SET p_out=2;  
-> SELECT p_out;  
-> END;  
-> //  
mysql > DELIMITER ;
로그인 후 복사
    执行结果:
mysql > SET @p_out=1;  
mysql > CALL sp_demo_out_parameter(@p_out);  
+-------+ 
| p_out |   
+-------+ 
| NULL  |   
+-------+ 
+-------+ 
| p_out |  
+-------+ 
|   2   |   
+-------+ 
mysql> SELECT @p_out;  
+-------+ 
| p_out |  
+-------+ 
|   2   |  
+-------+
로그인 후 복사

. INOUT参数例子

创建:

mysql > DELIMITER //  
mysql > CREATE PROCEDURE demo_inout_parameter(INOUT p_inout int)  
-> BEGIN
-> SELECT p_inout;  
-> SET p_inout=2;  
-> SELECT p_inout;   
-> END;  
-> //   
mysql > DELIMITER
로그인 후 복사

执行结果:

  1. mysql 
    mysql > CALL demo_inout_parameter(@p_inout) ;  
    +---------+  
    | p_inout |  
    +---------+  
    |    1    |  
    +---------+  
    +---------+  
    | p_inout |   
    +---------+  
    |    2    |  
    +---------+  
    mysql > SELECT @p_inout;  
    +----------+  
    | @p_inout |   
    +----------+  
    |    2     |  
    +----------+
    로그인 후 복사

(4). 变量

. 变量定义

DECLARE variable_name [,variable_name...] datatype [DEFAULT value];

其中,datatypeMySQL的数据类型,如:int, float, date, varchar(length)

例如:

DECLARE l_int int unsigned default 4000000;  
DECLARE l_numeric number(8,2) DEFAULT 9.95;  
DECLARE l_date date DEFAULT '1999-12-31';  
DECLARE l_datetime datetime DEFAULT '1999-12-31 23:59:59';  
DECLARE l_varchar varchar(255) DEFAULT 'This will not be padded';
로그인 후 복사

. 变量赋值

 SET 变量名 = 表达式值 [,variable_name = expression ...]
로그인 후 복사

. 用户变量

. MySQL客户端使用用户变量

  1. mysql > SELECT 'Hello World' into @x;  
    mysql > SELECT @x;  
    +-------------+ 
    |   @x        |  
    +-------------+ 
    | Hello World |  
    +-------------+ 
    mysql > SET @y='Goodbye Cruel World';  
    mysql > SELECT @y;  
    +---------------------+ 
    |     @y              |  
    +---------------------+ 
    | Goodbye Cruel World |  
    +---------------------+ 
    mysql > SET @z=1+2+3;  
    mysql > SELECT @z;  
    +------+ 
    | @z   |  
    +------+ 
    |  6   |  
    +------+
    로그인 후 복사

ⅱ. 在存储过程中使用用户变量

  1. mysql > CREATE PROCEDURE GreetWorld( ) SELECT CONCAT(@greeting,' World');  
    mysql > SET @greeting='Hello';  
    mysql > CALL GreetWorld( );  
    +----------------------------+ 
    | CONCAT(@greeting,' World') |  
    +----------------------------+ 
    |  Hello World               |  
    +----------------------------+
    로그인 후 복사

. 在存储过程间传递全局范围的用户变量

  1. mysql> CREATE PROCEDURE p1()   SET @last_procedure='p1';  
    mysql> CREATE PROCEDURE p2() SELECT CONCAT('Last procedure was ',@last_proc);  
    mysql> CALL p1( );  
    mysql> CALL p2( );  
    +-----------------------------------------------+ 
    | CONCAT('Last procedure was ',@last_proc  |  
    +-----------------------------------------------+ 
    | Last procedure was p1                         |  
    +-----------------------------------------------+
    로그인 후 복사

注意:

用户变量名一般以@开头

滥用用户变量会导致程序难以理解及管理

(5). 注释

MySQL存储过程可使用两种风格的注释

双模杠:--

该风格一般用于单行注释

c风格: 一般用于多行注释

例如:

mysql > DELIMITER //  
mysql > CREATE PROCEDURE proc1 --name存储过程名 
-> (IN parameter1 INTEGER)   
-> BEGIN
-> DECLARE variable1 CHAR(10);   
-> IF parameter1 = 17 THEN
-> SET variable1 = 'birds';   
-> ELSE
-> SET variable1 = 'beasts';   
-> END IF;   
-> INSERT INTO table1 VALUES (variable1);  
-> END
-> //  
mysql > DELIMITER ;
로그인 후 복사

4. MySQL存储过程的调用

call和你过程名以及一个括号,括号里面根据需要,加入参数,参数包括输入参数、输出参数、输入输出参数。具体的调用方法可以参看上面的例子。

5. MySQL存储过程的查询

我们像知道一个数据库下面有那些表,我们一般采用show tables;进行查看。那么我们要查看某个数据库下面的存储过程,是否也可以采用呢?答案是,我们可以查看某个数据库下面的存储过程,但是是令一钟方式。

我们可以用

select name from mysql.proc where db=’数据库名’;
或者
select routine_name from information_schema.routines where routine_schema='数据库名';
或者
show procedure status where db='数据库名';
로그인 후 복사

进行查询。

如果我们想知道,某个存储过程的详细,那我们又该怎么做呢?是不是也可以像操作表一样用describe 表名进行查看呢?

答案是:我们可以查看存储过程的详细,但是需要用另一种方法:

SHOW CREATE PROCEDURE 数据库.存储过程名;

就可以查看当前存储过程的详细。

6. MySQL存储过程的修改

ALTER PROCEDURE
로그인 후 복사

更改用CREATE PROCEDURE 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。

7. MySQL存储过程的删除

删除一个存储过程比较简单,和删除表一样:

DROP PROCEDURE
로그인 후 복사

MySQL的表格中删除一个或多个存储过程。

8. MySQL存储过程的控制语句

(1). 变量作用域

内部的变量在其作用域范围内享有更高的优先权,当执行到end。变量时,内部变量消失,此时已经在其作用域外,变量不再可见了,应为在存储
过程外再也不能找到这个申明的变量,但是你可以通过out参数或者将其值指派
给会话变量来保存其值。

mysql > DELIMITER //  
mysql > CREATE PROCEDURE proc3()  
     -> begin
     -> declare x1 varchar(5) default 'outer';  
     -> begin
     -> declare x1 varchar(5) default 'inner';  
     -> select x1;  
     -> end;  
     -> select x1;  
     -> end;  
     -> //  
mysql > DELIMITER
로그인 후 복사

(2). 条件语句

. if-then -else语句

mysql > DELIMITER //  
mysql > CREATE PROCEDURE proc2(IN parameter int)  
     -> begin
     -> declare var int;  
     -> set var=parameter+1;  
     -> if var=0 then
     -> insert into t values(17);  
     -> end if;  
     -> if parameter=0 then
     -> update t set s1=s1+1;  
     -> else
     -> update t set s1=s1+2;  
     -> end if;  
     -> end;  
     -> //  
mysql > DELIMITER ;
로그인 후 복사
    . case语句:
  1. mysql > DELIMITER //  
    mysql > CREATE PROCEDURE proc3 (in parameter int)  
         -> begin
         -> declare var int;  
         -> set var=parameter+1;  
         -> case var  
         -> when 0 then
         -> insert into t values(17);  
         -> when 1 then
         -> insert into t values(18);  
         -> else
         -> insert into t values(19);  
         -> end case;  
         -> end;  
         -> //  
    mysql > DELIMITER ;
    로그인 후 복사

(3). 循环语句

. while ···· end while

  1. mysql > DELIMITER //  
    mysql > CREATE PROCEDURE proc4()  
         -> begin
         -> declare var int;  
         -> set var=0;  
         -> while var<6 do  
         -> insert into t values(var);  
         -> set var=var+1;  
         -> end while;  
         -> end;  
         -> //  
    mysql > DELIMITER ;
    로그인 후 복사

. repeat···· end repeat

它在执行操作后检查结果,而while则是执行前进行检查。

  1. mysql > DELIMITER //  
    mysql > CREATE PROCEDURE proc5 ()  
         -> begin
         -> declare v int;  
         -> set v=0;  
         -> repeat  
         -> insert into t values(v);  
         -> set v=v+1;  
         -> until v>=5  
         -> end repeat;  
         -> end;  
         -> //  
    mysql > DELIMITER ;
    로그인 후 복사

. loop ·····end loop:

loop循环不需要初始条件,这点和while 循环相似,同时和repeat循环一样不需要结束条件, leave语句的意义是离开循环。

  1. mysql > DELIMITER //  
    mysql > CREATE PROCEDURE proc6 ()  
         -> begin
         -> declare v int;  
         -> set v=0;  
         -> LOOP_LABLE:loop  
         -> insert into t values(v);  
         -> set v=v+1;  
         -> if v >=5 then
         -> leave LOOP_LABLE;  
         -> end if;  
         -> end loop;  
         -> end;  
         -> //  
    mysql > DELIMITER ;
    로그인 후 복사

. LABLES 标号:

标号可以用在begin repeat while 或者loop 语句前,语句标号只能在合法的语句前面使用。可以跳出循环,使运行指令达到复合语句的最后一步。

(4). ITERATE迭代

. ITERATE:

通过引用复合语句的标号,来从新开始复合语句

mysql > DELIMITER //  
mysql > CREATE PROCEDURE proc10 ()  
     -> begin
     -> declare v int;  
     -> set v=0;  
     -> LOOP_LABLE:loop  
     -> if v=3 then
     -> set v=v+1;  
     -> ITERATE LOOP_LABLE;  
     -> end if;  
     -> insert into t values(v);  
     -> set v=v+1;  
     -> if v>=5 then
     -> leave LOOP_LABLE;  
     -> end if;  
     -> end loop;  
     -> end;  
     -> //  
mysql > DELIMITER ;
로그인 후 복사

9. MySQL存储过程的基本函数

(1).字符串类

CHARSET(str) //문자열 문자 집합을 반환합니다
CONCAT (string2 [,... ]) //연결 문자열
INSTR (string ,substring ) // string에서 substring이 처음 나타나는 위치를 반환합니다. 이 존재하지 않습니다. 반환 0
LCASE(string2 ) //
소문자로 변환

왼쪽 (string2 ,length ) // string2LENGTH(string ) //string
lengthLOAD_FILE( 파일_이름) //
파일에서 내용 읽기LOCATE (substring , string [,start_position ] )
INSTR,과 동일하지만 시작 위치를 지정할 수 있습니다LPAD(string2, length , pad ) //
문자열 길이가 lengthLTRIM (string2 ) //이 될 때까지 string,의 시작 부분에 pad을 반복해서 추가하세요. // 제거 선행 공백
REPEAT (string2 ,count ) //

repeatcounttimesREPLACE (str ,search_str ,replace_str ) //
에서 사용됩니다 str replace_str Replace search_strRPAD (string2 ,length ,pad) //다음에
str 추가 pad 길이가 이 될 때까지 lengthRTRIM ( string2 ) / /백엔드 공간 제거
STRCMP (string1 ,string2 ) //逐字符比较两字串大小,
SUBSTRING (str , position [,length ]) //
strposition开始,length个字符
,
注:mysql中处理字符串时,默认第一个字符下标为1,即参数position必须大于等于1

mysql> select substring(&#39;abcd&#39;,0,2);  
+-----------------------+ 
| substring(&#39;abcd&#39;,0,2) |  
+-----------------------+ 
|                       |  
+-----------------------+ 
1 row in set (0.00 sec)  
mysql> select substring(&#39;abcd&#39;,1,2);  
+-----------------------+ 
| substring(&#39;abcd&#39;,1,2) |  
+-----------------------+ 
|     ab                |  
+-----------------------+ 
1 row in set (0.02 sec)  
TRIM([[BOTH|LEADING|TRAILING] [padding] FROM]string2) //去除指定位置的指定字符
UCASE (string2 ) //转换成大写
RIGHT(string2,length) //取string2最后length个字符
SPACE(count) //生成count个空格
로그인 후 복사

(2).数学类

ABS (number2 ) //绝对值
BIN (decimal_number ) //十进制转二进制
CEILING (number2 ) //向上取整
CONV(number2,from_base,to_base) //进制转换
FLOOR (number2 ) //向下取整
FORMAT (number,decimal_places ) //保留小数位数
HEX (DecimalNumber ) //转十六进制
注:HEX()中可传入字符串,则返回其ASC-11,如HEX('DEF')返回4142143
也可以传入十进制整数,返回其十六进制编码,如HEX(25)返回
19
LEAST (number , number2 [,..]) //
求最小值

MOD (numerator ,denominator ) //求余
POWER (number ,power ) //求指数
RAND([seed]) //随机数
ROUND (number [,decimals ]) //四舍五入,decimals为小数位数]

注:返回类型并非均为整数,如:
(1)默认变为整形值

mysql> select round(1.23);  
+-------------+ 
| round(1.23) |  
+-------------+ 
|           1 |  
+-------------+ 
1 row in set (0.00 sec)  
mysql> select round(1.56);  
+-------------+ 
| round(1.56) |  
+-------------+ 
|           2 |  
+-------------+ 
1 row in set (0.00 sec)
로그인 후 복사
    (2)可以设定小数位数,返回浮点型数据
mysql> 
+----------------+ 
| round(1.567,2) |  
+----------------+ 
|           1.57 |  
+----------------+ 
1 row in set (0.00 sec) 
SIGN (number2 ) //
로그인 후 복사

(3).日期时间类

ADDTIME (date2 ,time_interval ) // time_intervaldate2
CONVERT_TZ (datetime2 ,fromTZ ,toTZ ) //
시간대 변환
CURR ENT_DATE ( ) //
현재 Date
CURRENT_TIME ( ) //
현재 시간
CURRENT_TIMESTAMP ( ) //
현재 타임스탬프
DATE (datetime ) //
날짜 부분을 반환합니다datetime
DATE_ADD( date2 , INTERVAL d_value d_type ) //
date2
DATE_FORMAT(datetime,FormatCodes)에 날짜 또는 시간 추가 //
formatcodes 형식을 사용하여 datetime을 표시합니다.
DATE_SUB(날짜2, INTERVAL d_value d_type ) //
date2
DATEDIFF (date1 ,date2 ) //
두 날짜의 차이
DAY (date ) //
Return 날짜 날짜
DAYNAME(날짜) //
영어 주간
DAYOFWEEK(날짜) //
week(1-7), 1은 일요일
DAYOFYEAR(날짜) //
연중일
EXTRACT(interval_name FROM 날짜) / /
date
MAKEDATE(연도,일)에서 날짜의 지정된 부분을 추출합니다. //
연도와 일자를 제공합니다,날짜 문자열을 생성합니다
MAKETIME( 시, 분, 초) //
시간 문자열 생성
MONTHNAME(날짜) //
영어 월 이름
NOW() //
현재 시간
SEC_TO_TIME(초) //
초를 시간으로 변환
STR_TO_DATE(문자열, 형식) //
문자열을 시간으로 변환, 형식 형식
TIMEDIFF(datetime1,datetime2)로 표시됨 //
두 번
time_to_sec (시간) //
시간 to Sec datetime) //월의 일
HOUR(datetime) //小时
LAST_DAY(date) //date
的月的最后日期
MICROSECOND(datetime) //
微秒
MONTH(datetime) //

MINUTE(datetime) //
返回符号,正负或0

SQRT(number2) //开平方

PHP调用MYSQL存储过程实例

实例一:无参的存储过程

$conn = mysql_connect(&#39;localhost&#39;,&#39;root&#39;,&#39;root&#39;) or die ("数据连接错误!!!");
mysql_select_db(&#39;test&#39;,$conn);
$sql = "
create procedure myproce()
begin
INSERT INTO user (id, username, sex) VALUES (NULL, &#39;s&#39;, &#39;0&#39;);
end; 
";
mysql_query($sql);//创建一个myproce的存储过程
$sql = "call test.myproce();";
mysql_query($sql);//调用myproce的存储过程,则数据库中将增加一条新记录。
로그인 후 복사

实例二:传入参数的存储过程

$sql = "
create procedure myproce2(in score int)
begin
if score >= 60 then
select &#39;pass&#39;;
else
select &#39;no&#39;;
end if;
end; 
";
mysql_query($sql);//创建一个myproce2的存储过程
$sql = "call test.myproce2(70);";
mysql_query($sql);//调用myproce2的存储过程,看不到效果,可以在cmd下看到结果。
로그인 후 복사

实例三:传出参数的存储过程

$sql = "
create procedure myproce3(out score int)
begin
set score=100;
end; 
";
mysql_query($sql);//创建一个myproce3的存储过程
$sql = "call test.myproce3(@score);";
mysql_query($sql);//调用myproce3的存储过程
$result = mysql_query(&#39;select @score;&#39;);
$array = mysql_fetch_array($result);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;print_r($array);
로그인 후 복사

实例四:传出参数的inout存储过程

$sql = "
create procedure myproce4(inout sexflag int)
begin
SELECT * FROM user WHERE sex = sexflag;
end; 
";
mysql_query($sql);//创建一个myproce4的存储过程
$sql = "set @sexflag = 1";
mysql_query($sql);//设置性别参数为1
$sql = "call test.myproce4(@sexflag);";
mysql_query($sql);//调用myproce4的存储过程,在cmd下面看效果
로그인 후 복사

实例五:使用变量的存储过程

$sql = "
create procedure myproce5(in a int,in b int)
begin
declare s int default 0;
set s=a+b;
select s;
end; 
";
mysql_query($sql);//创建一个myproce5的存储过程
$sql = "call test.myproce5(4,6);";
mysql_query($sql);//调用myproce5的存储过程,在cmd下面看效果
로그인 후 복사

实例六:case语法

$sql = "
create procedure myproce6(in score int)
begin
case score
when 60 then select &#39;及格&#39;;
when 80 then select &#39;及良好&#39;;
when 100 then select &#39;优秀&#39;;
else select &#39;未知分数&#39;;
end case;
end; 
";
mysql_query($sql);//创建一个myproce6的存储过程
$sql = "call test.myproce6(100);";
mysql_query($sql);//调用myproce6的存储过程,在cmd下面看效果
로그인 후 복사

实例七:循环语句

$sql = "
create procedure myproce7()
begin
declare i int default 0;
declare j int default 0;
while i<10 do
set j=j+i;
set i=i+1;
end while;
select j;
end; 
";
mysql_query($sql);//创建一个myproce7的存储过程
$sql = "call test.myproce7();";
mysql_query($sql);//调用myproce7的存储过程,在cmd下面看效果
로그인 후 복사

实例八:repeat语句

$sql = " 
create procedure myproce8()
begin
declare i int default 0;
declare j int default 0;
repeat
set j=j+i;
set i=i+1;
until j>=10
end repeat;
select j;
end; 
";
mysql_query($sql);//创建一个myproce8的存储过程
$sql = "call test.myproce8();";
mysql_query($sql);//调用myproce8的存储过程,在cmd下面看效果
로그인 후 복사

实例九:loop语句

$sql = "
create procedure myproce9()
begin
declare i int default 0;
declare s int default 0;
loop_label:loop
set s=s+i;
set i=i+1;
if i>=5 then
leave loop_label;
end if;
end loop;
select s;
end; 
";
mysql_query($sql);//创建一个myproce9的存储过程
$sql = "call test.myproce9();";
mysql_query($sql);//调用myproce9的存储过程,在cmd下面看效果
로그인 후 복사

实例十:删除存储过程

mysql_query("drop procedure if exists myproce");//删除test的存储过程
实例十:存储过程中的游标
로그인 후 복사

以上就是本篇文章的全部内容了,更多相关内容请关注PHP中文网。

相关推荐:

php调用mysql存储过程和函数的方法

위 내용은 mysql 저장 프로시저에 대한 자세한 설명과 PHP에서 MYSQL 저장 프로시저를 호출하는 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿