自学内容网 自学内容网

MySQL的存储过程

存储过程的概念:

为了完成特定功能的sql语句的集合,把定义号的sql集合在一个特定的sql的函数当中,每次执行调用函数即可,还可以实现传参的调用。

存储过程的语法:

delimiter $$

delimiter : 开始和结束的语法

$$:标志位,可以自定义,不要用汉字和数字以及特殊字符开头

create procedure +存储过程的名称 ()

begin

select * from 表名;

end $$

delimiter;

查看存储过程

show procedure  status  where db='库名';
​
show procedure  status  like  '%存储过程的名称%';

存储过程的作用:

执行速度要比sql语句执行速度更块,执行效率也更高。

客户端可以随时调用发放,也可以随时修改。

可以对数据做任何操作。

存储过程传参:

in 传入参数,调用者向存储过程传入值

delimiter $$
create procedure test1 (in uname char(20) )
begin
select * from info where name = uname;
select * from info;
end $$
delimiter;
 
call test1('小明');
#call 存储过程名(传参内容)
 
#数据清晰和指定数据入库。分析数据行为。

out 输出参数 存储过程向调用者传出值 可以是多个值

delimiter $$
create procedure test2(out num int)
BEGIN
set num=100;
end $$
delimiter;
call test2(@num)
select @num;
insert into info1 values (@num);

inout 输入输出 既可以表示存储过程向调用者传出,也可以表示用户向存储过程传入值。

delimiter $$
create procedure test3 (inout str varchar(10))
#定义了变量之后一定要定义数据类型是什么
BEGIN
select str;#在存储过程当中引用变量无需加@
#显示输入字符
set str = concat(str,'_ky32');
#把字符串进行替换
select str;
#加工之后的字符串
end $$
delimiter;
 
set @str='小明';
#先传参,在外部需要加上@
call test3(@str);
 
update info set name=@str where id = 1;
#看一下加工后str的内容

存储过程的控制语句:

delimiter $$
create procedure test4 (inout num int)
BEGIN
if num >=10 then
set num=num-5;
else
set num=num*2;
end if;
#结束if语句的判断
select num;
end $$
delimiter;
 
set @num=19;
 
call test5(@num);
 
update info set id = @num where score = 100;
————————————————

                           

调用多个参数

调用多个参数:范围的方式匹配,完成传参写入表中

delimiter $$
create procedure test7(inout score  int, out grade varchar(255))
BEGIN
if score between 85 and 100 THEN
set grade='优秀';
elseif score  between 60 and 84 then 
set grade='及格';
else
set grade='不及格';
end if;  
end $$
delimiter;

set @score=90;
call test7(@score,@grade);
insert into info2 values (1,@score,@grade);

while:循环语句

delimiter $$
create procedure test8(out rescult int)
BEGIN
declare a int;
declare i int;
#在过程体当中声明变量
set a=10;
set i=1;
while i<=10 do
set a=a+10;
set i=i+1;
#相当于i++
end while;
set rescult =a;
end $$
delimiter;
 
set @rescult=90;
 
call test8(@rescult);
 
select @rescult;


                     


原文地址:https://blog.csdn.net/2402_84868182/article/details/140693717

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!