--把若干条sql语句封装起来,起个名字,叫做过程,也是没有返回值的函数
--把这个过程存储在数据库中->存储过程
--存储过程的创建过程
create procedure proceduceName()
begin
sql 语句
end$
--查看
show procedure status \G
--调用
call procedureName()$
--声明变量
declare age int default 18;
--运算
set age:=age+10;
--改变边界
delimiter $
--例子
create procedure p1()
begin
declare age int default 18;
set age:=age+10;
select age;
end$
--用call p1()$调用时出现 age 28
--创建表
create table test(
id int,
name varchar(30) not null default '',
age int,
content varchar(40)
)engine myisam charset utf8$
--插入数据
insert into test values (1,'zhangsan',13,'学习好'),(2,'lisi',15,'智慧的化身'),(2,'wangwu',14,'不起眼')$
--存储过程存储sql语句
create procedure p2()
begin
select content from test where age=15;
end$
--存储过程是可以编程的
--意味着可以使用变量,表达式,控制结构完成复杂的功能
--if/else语句的使用
if 条件 then
语句;
else if 条件 then
语句;
else
语句;
end if;
create procedure p3()
begin
declare age int default 18;
if age>=18 then
select '你已经成年了';
else
select '未成年';
end if;
end$
--while 循环
while 条件 do
语句;
end while;
--括号里可以声明参数
--参数类型 [in/out/inout] 参数名 参数类型
create procedure p4(agee int)
begin
select name from test where age=agee;
end$
in 表示输入参数 传参
out 表示输出参数 传变量名 向外传值 要设置初始化值
inout 输入参数执行后再输出 传入一个声明过的变量名
create procedure p5(in age int)
begin
select age as '你几岁了';
end$
--out 参数,要在procedure 内部初始化参数
create procedure p6(out result int)
begin
declare i int default 1;
set result:=0;
while i<=100 do
set result:=result+i;
set i:=i+1;
end while;
end$
--调用
call p6(@num)$
select @num$
--inout 参数
create procedure p7(inout age int)
begin
set age:=age+10;
select age as '10年后你几岁了';
end$
set @age=10$
call p7(@age)$
select @age$
--case语句
case 变量名
when 值1 then 操作1;
when 值2 then 操作2;
...
else 操作n;
end case;
--repeat 循环
repeat
操作语句
until 条件 end repeat;