当前位置:   article > 正文

MySQL的存储过程

MySQL的存储过程

存储过程的概念:

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

存储过程的语法:

delimiter $$

delimiter : 开始和结束的语法

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

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

begin

select * from 表名;

end $$

delimiter;

查看存储过程

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

存储过程的作用:

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

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

可以对数据做任何操作。

存储过程传参:

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

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

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

  1. delimiter $$
  2. create procedure test2(out num int)
  3. BEGIN
  4. set num=100;
  5. end $$
  6. delimiter;
  7. call test2(@num)
  8. select @num;
  9. insert into info1 values (@num);

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

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

存储过程的控制语句:

  1. delimiter $$
  2. create procedure test4 (inout num int)
  3. BEGIN
  4. if num >=10 then
  5. set num=num-5
  6. else
  7. set num=num*2;
  8. end if;
  9. #结束if语句的判断
  10. select num;
  11. end $$
  12. delimiter;
  13. set @num=19;
  14. call test5(@num);
  15. update info set id = @num where score = 100;
  16. ————————————————

调用多个参数

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

  1. delimiter $$
  2. create procedure test7(inout score int, out grade varchar(255))
  3. BEGIN
  4. if score between 85 and 100 THEN
  5. set grade='优秀';
  6. elseif score between 60 and 84 then
  7. set grade='及格';
  8. else
  9. set grade='不及格';
  10. end if;
  11. end $$
  12. delimiter;
  13. set @score=90;
  14. call test7(@score,@grade);
  15. insert into info2 values (1,@score,@grade);

while:循环语句

  1. delimiter $$
  2. create procedure test8(out rescult int)
  3. BEGIN
  4. declare a int;
  5. declare i int;
  6. #在过程体当中声明变量
  7. set a=10;
  8. set i=1;
  9. while i<=10 do
  10. set a=a+10;
  11. set i=i+1;
  12. #相当于i++
  13. end while;
  14. set rescult =a;
  15. end $$
  16. delimiter;
  17. set @rescult=90;
  18. call test8(@rescult);
  19. select @rescult;

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/903818
推荐阅读
相关标签
  

闽ICP备14008679号