Maison > base de données > tutoriel mysql > Maîtrisez les procédures stockées de MySQL dans un seul article

Maîtrisez les procédures stockées de MySQL dans un seul article

WBOY
Libérer: 2022-05-27 15:04:43
avant
2302 Les gens l'ont consulté

Cet article vous apporte des connaissances pertinentes sur mysql. Il présente principalement du contenu connexe sur les procédures stockées, y compris le transfert de paramètres de procédure stockée, le contrôle de processus, la gestion du curseur et des exceptions, etc. .

Maîtrisez les procédures stockées de MySQL dans un seul article

Apprentissage recommandé : Tutoriel vidéo MySQL

MySQL version 5.0 commence à prendre en charge les procédures stockées. Les procédures stockées sont un ensemble d'instructions SQL. Elles sont puissantes et peuvent implémenter des fonctions logiques plus complexes, similaires à celles du. Langage JAVA. La méthode de stockage est l'encapsulation et la réutilisation de la base de données SQL et du code au niveau de la couche

1. Il existe des paramètres d'entrée et de sortie, des variables peuvent être déclarées et des instructions de contrôle telles que if/else/case/while, etc. peut être réalisé en écrivant des procédures stockées.

2. Caractéristiques communes des fonctions : modularisation, encapsulation, réutilisation du code

3. Rapide, seule la première exécution nécessite des étapes de compilation et d'optimisation, les appels suivants peuvent être exécutés directement, éliminant ainsi les étapes de compilation et d'optimisation. étapes ci-dessus

Format

Créer une procédure stockée

-- 创建存储过程
delimiter $$
create procedure proc01()
begin
	select empno,ename from emp;
end $$
delimiter ;
-- 调用存储过程
call proc01;
Copier après la connexion

Définir des variables

Variables locales

Définies par l'utilisateur, valides dans les blocs de début/fin

delimiter $$
create procedure proc02()
begin
	declare var_name01 varchar(20) default 'aaa';  -- 声明/定义变量
	set var_naem01 = 'zhangsan'; -- 给变量赋值
	select var_name01; -- 输出变量的值
end $$
dilimiter ;
call proc02();
Copier après la connexion

Variables utilisateur

Défini par l'utilisateur, la session actuelle (connexion) est valide. Analogie avec les variables membres de Java

delimiter $$
create procedure proc04()
begin
	set @var_name01 = 'beijing';
	select @var_name01;
end $$
dilimiter ;
call proc04();
select @var_name01; -- 外部也是可以使用用户变量
Copier après la connexion

variables système

1. Les variables système sont divisées en variables globales et variables de session

2. . Les variables globales sont démarrées dans MYSQL Lorsque le serveur l'initialise automatiquement à la valeur par défaut, ces valeurs par défaut peuvent être modifiées en modifiant le fichier my.ini

3. Les variables de session sont initialisées par MYSQL à chaque nouvelle connexion. est établi et MYSQL copiera les valeurs de toutes les variables globales actuelles en tant que variables de session

4 En d'autres termes, si les valeurs des variables de session et des variables globales ne sont pas modifiées manuellement après l'établissement de la session, alors le les valeurs de toutes ces variables seront les mêmes

5. La différence entre les variables globales et les variables de session est que les modifications apportées aux variables globales affecteront l'ensemble du serveur, mais les modifications apportées aux variables de session n'affecteront que la session en cours (c'est-à-dire que la connexion actuelle à la base de données)

6. Les valeurs de certaines variables système peuvent être modifiées dynamiquement à l'aide d'instructions, mais les valeurs de certaines variables système sont en lecture seule. Pour les variables système qui peuvent être modifiées, nous pouvons utiliser. l'instruction set pour les modifier

Variables système - variables globales

Il est valide dans toute la base de données par le système system

Procédure stockée

Le paramètre de procédure stockée-in

in représente le paramètres entrants, vous pouvez transmettre des valeurs ou des variables, même si vous transmettez des variables, ne modifie pas la valeur de la variable, elle peut être modifiée en interne et n'agit que dans le cadre de la fonction

delimiter $$
create procedure proc06(in param_empno int)
begin
	select*from emp where empno = param_empno
end $$
delimiter ;
call proc06(1001);
Copier après la connexion

Passer plusieurs paramètres

Passer des paramètres aux procédures stockées -out

out signifie transmettre des paramètres depuis la procédure stockée La valeur est donnée à l'appelant

Procédure stockée paramètre-inout

inout représente la variable qui peut être renvoyé après modification des paramètres passés de l'extérieur. Vous pouvez soit utiliser la valeur de la variable entrante, soit modifier la valeur de la variable (même si la fonction est exécutée)

.

流程控制

流程控制-判断

IF语句包含多个条件判断,根据结果为TURE和FALSE执行语句,与编程语言中的if、else if、else语法类似,其语法格式如下

-- 存储过程-if
-- 案例1
-- 输入学生的成绩,来判断成绩的级别
/*
score<60:不及格
score>=60 , score<80 :及格
score>=80 , score<90 :良好
score>=90 , score<=100 :优秀
score>100 :成就错误
*/
delimiter $$
create procedure proc_12_if (in score int)
begin
	if score<60 then select &#39;不及格&#39;;
	elseif score>=60 and score<80 then select &#39;及格&#39;;
	elseif score>=80 and score<90 then select &#39;良好&#39;;
	elseif score>=90 and score<=100 then select &#39;优秀&#39;;
	else select &#39;成绩错误&#39;
	end if;
end $$
delimiter ;

set @score=55;
call proc_12_if(@score)
Copier après la connexion
-- 输入员工的名字,判断工资的情况
/*
sal<10000 :适用薪资
sal>=10000 and sal<20000 :转正薪资
sal>=20000 :元老薪资
*/
delimiter $$
create procedure proc_13_if(in in_ename varchar)
begin
	declare var_sal decimal(7,2);  -- 定义局部变量,7个长度,2个小数 
	declare result varchar(20);
	select sal into var_sal from emp where ename=in_eanme;  -- 将值赋给局部变量
	if var_sal <10000 then set result ='适用薪资';
	elseif var_sal <20000 then set result ='转正薪资';
	else set result ='元老薪资';
	end if;
	select result;
end$$
delimiter ;

-- 调用
call proc_13_if('刘备');
Copier après la connexion

流程控制语句-case 

 CASE是另一个条件判断语句,类似于编程语言中的switch语法

语法一:当case后面的语句与when后面的语句相等时,则会执行then后面的语句,如果均不匹配则执行else

语法二:直接写case 当when后面的条件成立则执行then后面的语句,如果都不成立,则执行else

-- 流程控制语句:case
/*
支付方式:
	1.微信支付
	2.支付宝支付
	3.银行卡支付
	4.其他支付
*/
-- 格式1
delimiter $$
create procedure proc14_case(in pay_type int)
begin
	case pay_type 
	when 1 then select '微信支付';
	when 2 then select '支付宝支付';
	when 3 then select '银行卡支付';
	else select '其他方式支付';
	end case;
end$$
delimiter ;

call proc14_case(2);
call proc14_case(3);
Copier après la connexion
-- 语法二
-- 输入学生的成绩,来判断成绩的级别
/*
score<60:不及格
score>=60 , score<80 :及格
score>=80 , score<90 :良好
score>=90 , score<=100 :优秀
score>100 :成就错误
*/
delimiter $$
create procedure proc_15_case (in score int)
begin
	case
	when score<60 then select &#39;不及格&#39;;
	when score>=60 and score<80 then select &#39;及格&#39;;
	when score>=80 and score<90 then select &#39;良好&#39;;
	when score>=90 and score<=100 then select &#39;优秀&#39;;
	else select &#39;成绩错误&#39;
	end case;
end $$
delimiter ;

call proc_15_case(88);
Copier après la connexion

控制流程-循环

概述

循环是一段在程序中只出现一次,但可能会连续运行多次的代码

循环中的代码会运行特定的次数,或者是运行到特定条件成立时结束循环

循环分类

while、repeat、loop

循环控制

leave 类似于break,跳出,结束当前所在的循环

iteater 类似于continue,继续,结束本次循环,继续下一次

while循环

-- 需求:向表中添加指定条数据
-- while
delimiter $$
create procedure proc16_while(in insertCount int)
begin
	declare i int default 1;  -- 设置循环的增量
	label:while i<=insertCount do insert into user(id,username,password) values(i,concat(&#39;user-&#39;,i),&#39;123456&#39;);
	set i=i+1;
end while label;
end$$
delimiter ;


call proc16_while(10);
Copier après la connexion
-- 需求:向表中添加指定条数据
-- while+leave
delimiter $$
create procedure proc16_while(in insertCount int)
begin
	declare i int default 1;  -- 设置循环的增量
	label:while i<=insertCount do insert into user(id,username,password) values(i,concat(&#39;user-&#39;,i),&#39;123456&#39;);
	if i=5 then leave label;   -- 如果i=5则跳出循环
	set i=i+1;
end while label;
end$$
delimiter ;


call proc16_while(10);
Copier après la connexion

repeat循环

格式

-- 存储过程-循环控制-repeat

delimiter $$
create procedure proc18_repaet(in insertCount int)
begin
	declare i int default 1;
	label:repeat
		insert into user(uid,username,password)values(i,concat(&#39;user-&#39;,i),&#39;123456&#39;);
		set i = i+1;
		until i>inserCount  -- 这里不能写; 表示跳出循环
		end repeat label;
		select '循环结束';
end$$
delimiter ;

call proc18_repeat(100);
Copier après la connexion

loop循环

-- 存储过程-循环控制-loop

delimiter $$
create procedure proc19_loop(in insertCount int)
begin
	declare i default 1;
	label:loop insert into user (uid,username,password) values (i,concat('user-')i,'123456');
	set i= i+1;
	if i>insertCount then leave label;
	end if;
	end loop label;
end$$
delimiter ;

call proc19_loop()
Copier après la connexion

游标

游标(cursor)是庸才存储查询结果集的数据类型,在存储过程和函数中可以使用光标对结果集进行循环的处理,光标的使用包括光标的声明、OPEN、FETCH、CLOSE

-- 操作游标(cursor)
-- 声明游标
-- 打开游标
-- 通过游标获取值
-- 关闭游标
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc19_cursor(in in_danme varchar(50))
begin
 -- 定义局部变量
	declare var_empno int;
	declare var_ename varchar(50);
	declare var_sal decimal(7,2);
 -- 声明游标
	declare my_cursor cursor for select empno,ename,sal from dept a,emp b where a.deptno=b.deptno and a.dname=in_dname;
 -- 打开游标
	open my_cursor;
 -- 通过游标获取值
-- 	fetch my_cursor into var_empno,var_ename,var_sal;
-- 	select var_empno,var_ename,var_sal;  -- 注意:以上两句只可以获取一个数据,因为游标是一次一行,所以采用循环
	label:loop
		fetch my_cursor into var_empno,var_ename,var_sal;
		select var_empno,var_ename,var_sal; 
	end loop label;
 -- 关闭游标
 close my_cursor;
end$$
delimiter ;

call proc19_cursor('销售部');
Copier après la connexion

异常处理-HANDLER句柄

MySQL存储过程也提供了对异常处理的功能:通过定义HANDLER来完成异常声明的实现

格式

在语法中,变量声明、游标声明、handler声明必须按照先后顺序书写的,否则创建存储过程出错

DECALARE handler_action 创建句柄

FOR 后面为条件值,为什么异常提供处理

statment 当没有数据发现这个异常发生时采取什么措施

handler_action :{

        CONTINUE    继续执行

        EXIT 退出

        UNDO 取消(目前MySQL不支持)

}

condition_value :{

mysql_error_code  错误码

condition 条件名

SQLWARNING   SQL警告

NOT FOUND  数据没有发现

SQLEXCEPTION  SQL异常

}

/*用于测试句柄,改造上面游标代码会出现1329错误代码的情况*/
-- 操作游标(cursor)
-- 声明游标
-- 打开游标
-- 通过游标获取值
-- 关闭游标
-- 需求:输入一个部门名,查询该部门员工的编号、名字、薪资,将查询的结果集添加游标
delimiter $$
create procedure proc21_cursor_handler(in in_danme varchar(50))
begin
 -- 定义局部变量
	declare var_empno int;
	declare var_ename varchar(50);
	declare var_sal decimal(7,2);
 -- 定义标记值
	declare flag int default 1;
 -- 声明游标
	declare my_cursor cursor for select empno,ename,sal from dept a,emp b where a.deptno=b.deptno and a.dname=in_dname;
 -- 定义句柄:定义异常的处理方式
 /*
 1:异常处理完之后,程序应该如何执行
		continue :继续执行剩余代码
		exit:直接终止程序
		undo:不支持
 2:触发条件
		条件码:1329.....
		条件名:
					SQLWARNING
					NOT FOUND
					SQLEXCEPTION
 3:异常触发之后执行什么代码
		设置flag的值 -> 0 
 */
  declare continue handler for 1329 set flag=0 ;
 -- 打开游标
	open my_cursor;
 -- 通过游标获取值
-- 	fetch my_cursor into var_empno,var_ename,var_sal;
-- 	select var_empno,var_ename,var_sal;  -- 注意:以上两句只可以获取一个数据,因为游标是一次一行,所以采用循环
	label:loop
		fetch my_cursor into var_empno,var_ename,var_sal;
		-- 判断flag的值如果为1则执行,否则不执行
		if flag =1 then 
		 select var_empno,var_ename,var_sal; 
		else leave label;
		end if;
	end loop label;
 -- 关闭游标
 close my_cursor;
end$$
delimiter ;

call proc19_cursor('销售部');
Copier après la connexion

推荐学习: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!

Étiquettes associées:
source:csdn.net
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal