Maison  >  Article  >  développement back-end  >  Explication détaillée des procédures stockées MySQL et exemples d'appel de procédures stockées MYSQL à partir de PHP

Explication détaillée des procédures stockées MySQL et exemples d'appel de procédures stockées MYSQL à partir de PHP

不言
不言original
2018-05-09 10:06:191482parcourir

Cet article présente principalement l'explication détaillée des procédures stockées MySQL et des exemples de PHP appelant des procédures stockées MYSQL. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer

<.>Explication détaillée des procédures stockées MySQL

1.  Introduction aux procédures stockées

Notre langage de base de données d'exploitation couramment utiliséSQL instructions doivent d'abord être exécutés lors de l'exécution de Compile, puis exécutés, et la procédure stockée (Stored Procedure) est un ensemble d'instructions SQL pour compléter une fonction spécifique. Après compilation, elle est stockée dans la base de données. L'utilisateur l'appelle et l'exécute en spécifiant le nom de la procédure stockée et en donnant des paramètres (si la procédure stockée a des paramètres).

Une procédure stockée est une fonction programmable qui est créée et enregistrée dans la base de données. Il peut être composé d'instructions SQL et de quelques structures de contrôle spéciales. Les procédures stockées sont utiles lorsque vous souhaitez exécuter la même fonction sur différentes applications ou plates-formes, ou encapsuler des fonctionnalités spécifiques. Les procédures stockées dans une base de données peuvent être considérées comme une simulation de l’approche orientée objet en programmation. Il permet de contrôler la manière dont les données sont accessibles.

Les procédures stockées présentent généralement les avantages suivants :

(1). Les procédures stockées améliorent la puissance et la flexibilité du langage SQL. Les procédures stockées peuvent être écrites à l'aide d'instructions de contrôle de flux, sont très flexibles et peuvent effectuer des jugements complexes et des opérations plus complexes.

(2). Les procédures stockées permettent de programmer des composants standards. Une fois qu'une procédure stockée est créée, elle peut être appelée plusieurs fois dans le programme sans avoir à réécrire l'instruction SQL de la procédure stockée. Et les professionnels des bases de données peuvent modifier les procédures stockées à tout moment sans affecter le code source de l'application.

(3). Les procédures stockées peuvent atteindre une vitesse d'exécution plus rapide. Si une opération contient un grand nombre de codes Transaction-SQL ou est exécutée plusieurs fois, la procédure stockée s'exécutera beaucoup plus rapidement que le traitement par lots. Parce que les procédures stockées sont précompilées. Lorsqu'une procédure stockée est exécutée pour la première fois, la requête est analysée et optimisée par l'optimiseur et un plan d'exécution est finalement stocké dans la table système. L'instruction batch Transaction-SQL doit être compilée et optimisée à chaque exécution, et la vitesse est relativement plus lente.

(4).Les procédures du magasin peuvent réduire le trafic réseau. Pour les opérations sur le même objet de base de données (comme une requête, une modification), si l'instruction Transaction-SQL impliquée dans cette opération est organisée en procédure stockée, alors lorsqu'elle est appelée sur le client ordinateur Lorsque cette procédure stockée est exécutée, seule l'instruction d'appel est transmise sur le réseau, augmentant ainsi considérablement le trafic réseau et réduisant la charge du réseau.

(5). Les procédures stockées peuvent être pleinement utilisées comme mécanisme de sécurité. En restreignant les autorisations d'exécution d'une certaine procédure stockée, l'administrateur système peut limiter les autorisations d'accès aux données correspondantes, empêcher les utilisateurs non autorisés d'accéder aux données et assurer la sécurité des données.

2.  À proposMySQL

est une fonction importante du stockage de base de données, mais MySQL ne prenait pas en charge les procédures stockées avant 5.0, qui créait MySQLDe grosses réductions sur les applications. Heureusement, MySQL 5.0 prend enfin en charge les procédures stockées, ce qui peut grandement améliorer la vitesse de traitement de la base de données et également améliorer la flexibilité de la programmation de la base de données.

3.  MySQLCréation de procédures stockées

(1). Formater

MySQL Format de création de procédure stockée : CREATE PROCEDURE Nom du processus ([Paramètres du processus [,...]])
[
Caractéristique ...] Procédure

Voici un exemple :

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

Remarque :

(1 ) Ce qu'il faut noter ici, ce sont les deux phrases DELIMITER // et DELIMITER; > DELIMITER signifie le délimiteur, car MySQL est par défaut ";" comme délimiteur, si nous si le délimiteur n'est pas déclaré, le compilateur traitera la procédure stockée comme une instruction SQL, et le processus de compilation de la procédure stockée signalera une erreur, vous devez donc utiliser DELIMITER à l'avance Le mot-clé déclare le séparateur de segment actuel, afin que MySQL traite ";" sous forme de procédure stockée Le code ne sera pas exécuté et le séparateur devra être restauré après utilisation.

(2) La procédure stockée peut avoir des paramètres d'entrée, de sortie, d'entrée et de sortie selon les besoins. Voici un paramètre de sortie s, le type est int S'il y a plusieurs paramètres, utilisez "," pour séparer. eux.

(3) Le début et la fin du processus d'utilisation du corps BEGIN est marqué de FIN.

De cette façon, une de nos procédures stockées MySQL est terminée, n'est-ce pas très simple ?Peu importe si vous ne le comprenez pas, nous l'expliquerons ensuite en détail.

(2). Séparateur de déclaration

En fait, concernant le séparateur de déclaration, l'annotation ci-dessus a été écrite très clairement. Il n'est pas nécessaire d'en dire plus. Juste une chose à noter : si vous utilisez MySQLQuand. en utilisant l'Administrateur pour gérer les outils, vous pouvez les créer directement et vous n'avez plus besoin de les déclarer.

(3). Paramètres

MySQLLes paramètres des procédures stockées sont utilisés dans la définition des procédures stockées. Il existe trois types de paramètres , IN, OUT, INOUT, Formulaire tel que :

CREATE PROCEDURE([[IN |OUT |INOUT ] Nom du paramètre Type de données ...])

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 &#39;1999-12-31&#39;;  
DECLARE l_datetime datetime DEFAULT &#39;1999-12-31 23:59:59&#39;;  
DECLARE l_varchar varchar(255) DEFAULT &#39;This will not be padded&#39;;

. 变量赋值

 SET 变量名 = 表达式值 [,variable_name = expression ...]

. 用户变量

. MySQL客户端使用用户变量

  1. mysql > SELECT &#39;Hello World&#39; into @x;  
    mysql > SELECT @x;  
    +-------------+ 
    |   @x        |  
    +-------------+ 
    | Hello World |  
    +-------------+ 
    mysql > SET @y=&#39;Goodbye Cruel World&#39;;  
    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,&#39; World&#39;);  
    mysql > SET @greeting=&#39;Hello&#39;;  
    mysql > CALL GreetWorld( );  
    +----------------------------+ 
    | CONCAT(@greeting,&#39; World&#39;) |  
    +----------------------------+ 
    |  Hello World               |  
    +----------------------------+

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

  1. mysql> CREATE PROCEDURE p1()   SET @last_procedure=&#39;p1&#39;;  
    mysql> CREATE PROCEDURE p2() SELECT CONCAT(&#39;Last procedure was &#39;,@last_proc);  
    mysql> CALL p1( );  
    mysql> CALL p2( );  
    +-----------------------------------------------+ 
    | CONCAT(&#39;Last procedure was &#39;,@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 = &#39;birds&#39;;   
-> ELSE
-> SET variable1 = &#39;beasts&#39;;   
-> 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=&#39;数据库名&#39;;
或者
show procedure status where db=&#39;数据库名&#39;;

进行查询。

如果我们想知道,某个存储过程的详细,那我们又该怎么做呢?是不是也可以像操作表一样用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 &#39;outer&#39;;  
     -> begin
     -> declare x1 varchar(5) default &#39;inner&#39;;  
     -> 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) //renvoie le jeu de caractères de chaîne
CONCAT (string2 [,... ]) // Chaîne de connexion
INSTR (string,substring) //retournesous-chaîne apparaît pour la première fois dans chaîne, n'existe pas et renvoie 0LCASE (string2) //
convertir en minuscules

LEFT (string2,length) // Prendre longueur caractères à partir de la gauche dans chaîne2
LONGUEUR (chaîne) / /stringLongueur
LOAD_FILE (file_name) //Lire le contenu du fichier
LOCATE (substring, string [,start_position]) Identique à INSTR, mais vous pouvez spécifier la position de départ
LPAD (string2 ,length ,pad ) //Réutilisez pad et ajoutez-le à chaîne commence par , jusqu'à ce que la longueur de la chaîne soit longueurLTRIM (string2 ) / /
Supprimer les espaces de début

REPEAT (string2,count) //Répétercount fois
REPLACE (str ,search_str ,replace_str ) // est utilisé dans str >replace_strRemplacersearch_strRPAD (string2, length, pad) //
dans
str est ensuite complété par pad, jusqu'à ce que la longueur soit
longueurRTRIM (string2) //
Supprimer les espaces back-end
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 ) //Ajouter time_interval à date2
CONVERT_TZ ( datetime2 ,fromTZ ,toTZ ) //
Convertir le fuseau horaire
CURRENT_DATE ( ) //
Date actuelle
CURRENT_TIME ( ) //
Heure actuelle
CURRENT_TIMESTAMP ( ) //
Horodatage actuel
DATE (datetime ) //
Renvoie la partie date de datetime
DATE_ADD (date2, INTERVAL d_value d_type) //
dans date2Ajouter une date ou une heure
DATE_FORMAT (datetime,FormatCodes) //
Utiliser formatcodesFormat d'affichagedatetime
DATE_SUB (date2, INTERVAL d_value d_type) //
Soustraire un de date2Heure
DATEDIFF (date1 ,date2 ) //
Différence entre deux dates
DAY (date ) //
Retour Jour de la date
DAYNAME (date) //
jour de la semaine en anglais
DAYOFWEEK (date) //
jour de la semaine(1-7), 1 est dimanche
DAYOFYEAR (date) //
Jour de l'année
EXTRACT (interval_name FROM date ) //
from date Extraire la partie spécifiée de la date
MAKEDATE (année, jour) //
donne l'année et le jour de l'année ,Générer la date string
MAKETIME (heure, minute, seconde) //
Générer une chaîne d'heure
MONTHNAME (date) //
Nom du mois en anglais
NOW ( ) //
Heure actuelle
SEC_TO_TIME (secondes) //
secondes Convertir le nombre en time
STR_TO_DATE (string,format) //
la chaîne est convertie en time, au format Format d'affichage
TIMEDIFF (datetime1, datetime2) //
Deux décalages horaires
TIME_TO_SEC (time) //
Temps en secondes]
SEMAINE (date_time [,start_of_week ]) //
Semaine de la semaine
ANNÉE (dateheure ) //
Année
DAYOFMONTH(datetime) //
Jour du mois
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存储过程和函数的方法

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn