阅读量:0
一、存储过程
1、概念
为了完成特定功能sql语句的集合,把定义好的的sql集合在一个特定的sql函数当中,每次执行调用函数即可,还可以实现传参的调用
2、作用
执行速度要比sql语句执行速度更快,执行效率也更高
客户端可以随时调用发放,也可以随时修改,可以对数据库做任何操作,
3、语法
创建库和表
create database xy102; create table info1 ( id int(2) primary key, name varchar(10), high int(3), address varchar(15) );
3.1 delimiter $$
delimiter
是开始和结束语法,$$
是标志位,可以自定义,不要用汉字或者数字开头,不能使用特殊字符开头
delimiter $$ create procedure test1 () begin select * from info1; end $$ delimiter; # 查看存储过程命令 1.1 show procedure status where db='xy102'; 1.2 show procedure status like '%test1%'; # 直接在表中编辑信息后,执行存储命令id=1,name=小戴,high=167,address=南京 # 执行存储过程命令 call test1; delimiter $$ create procedure test2 () begin select * from info1; update info1 set high=180 where id = 1; end $$ delimiter; call test2;
3.2 存储过程传参
in
传入参数,调用者向存储过程传入值out
输出参数,存储过程向调用者传出值,可以是多个值inout
输入输出 既可以表示存储过程向调用者传出,也可以表示用户向存储过程传入值
delimiter $$ create procedure test3 (in uname char(20)) BEGIN SELECT * from info1 where name = uname; END $$ delimiter; # 直接在表中编辑信息后,执行存储命令id=2,name=小黄,high=172,address=南京 call test3 ('小黄'); # 显示信息为name=小黄的行
3.3 输出参数
delimiter $$ create procedure test4( out id int, out name char(10), out high int, out address varchar(10) ) begin set id=3,name='王心凌',high=185,address ='幸云教育'; end $$ delimiter; call test4(@id,@name,@high,@address) select @id,@name,@high,@address; insert into info1 values(@id,@name,@high,@address);
3.4 输入输出参数
在存储过程当中存储过程是不需要加@的
delimiter $$ create procedure test7(inout str varchar(10)) begin select str; # 在存储过程当中存储过程是不需要加@的 set str=concat(str,'_xy102'); # 替换 把字符换成进行替换 select str; end $$ delimiter; set @str='蔡依林'; call test7(@str); update info1 set name=@str where id = 3; # 把王心凌 high=185改成王心凌 high=195 delimiter $$ create procedure test8(inout ht varchar(10)) begin set ht=ht+10; end $$ delimiter; set @ht=185; call test8(@ht); update info1 set name=@ht where id = 3;
3.5 存储过程的控制语句
delimiter $$ create procedure test9(inout num int) begin if num >=10 then set num=num-5; else set num=num*2; end if end $$ delimiter; set @num=19 call test9(@num) update info1 set id=@num where high =111;