赞
踩
为了完成特定功能的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的内容
-
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
存储过程的控制语句:
- 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;
- ————————————————
-
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
调用多个参数:范围的方式匹配,完成传参写入表中
- 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);
-
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
- 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://csdnimg.cn/release/blogv2/dist/pc/img/newCodeMoreWhite.png)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。