Bootstrap

MySQL存储过程

存储过程:

事先经过编译并存储在数据库中的一段sql语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的,思想上就是sql语言层面的代码封装与重用

特点:封装,重用 可以接收数据,也可以返回数据 减少网络交互,提高效率

创建:

craeture procedure 存储过程名称([参数列表])
begin
    sql语句;
end;    

调用:

call 名称([参数列表])

查看指定数据库的存储过程及状态信息

select * from information_schema.routines where routine_schema ='xxx';

查询某个存储过程的定义

show create procedure 存储过程名称

删除

drop procedure [if exists] 存储过程名称

注意:在命令行中,执行创建存储过程的sql时,需要通过关键字delimiter指定sql语句的结束符

表示当前sql以$$结束
delimiter $$ 

变量:

系统变量:

是mysql服务器提供的,不是用户定义的,属于服务器层面。分为全局变量(global)和会话变量(session)

查看所有系统变量

show [session|global] variables;

可以通过like模糊匹配方式查找变量

show [session|global] variables like '……';

查看指定变量的值

select @@[session|global] 系统变量名

设置系统变量

set [session|global] 系统变量名 = 值;
set @@[session|global]系统变量名 = 值;

注:

若没有指定session|global,默认session,会话变量

mysql服务重新启动后,所设置的全局参数会失效,要想不失效,可以在/etc/my.cnf中配置

用户自定义变量:

是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用"@变量名"使用就可以,其作用域为当前连接

赋值

set @var_name = expr [,@var_name = expr]...;
set @var_name := expr [,@var_name = expr]...;
select @var_name := expr [,@var_name := expr]...;
select 字段名 into @var_name from 表明;

使用

select @var_name;

注:用户定义的变量无需对其进行声明或初始化,只不过获取的值为mull

局部变量:

是根据需要定义的在局部生效的变量,访问之前,需要declare声明,可以作用在存储过程内的局部变量和输入参数,局部变量的范围是在其内声明的begin……end块

声明

declare 变量名 变量类型 [default...]

赋值

set 变量名 = 值
set 变量名 = 值
select 字段 into 变量名 from 表明...;

If

语法

 if 条件 then
    ...
 elseif 条件2 then
    ...
 else
    ...
 end if;         

根据定义的分数score变量,判定当前分数对应的分数等级

score>= 85,等级为优秀

score>= 60 且 score <85,等级为及格

Score < 60,等级为不及格

参数

In 作为输入,调用时传入值 默认

Out 输出,作为返回值

Inout 即可做输入,也可做输出

用法

create procedure 存储过程名称([in/out/inout 参数名 参类型])
begin
    sql语句
end;    

将传入的200分制的分数,进行换算,换算成百分制,然后返回分数

case

用法

第一种
case case_value
    when when_value1 then statement_list1
    [when when_value2 then statement_list2]...
    [else statement_list]
end case;
第二种
case
    when search_condition1 then statement_list1
    [when search_condition2 then statement_list2]...
    [else statemen_list]
end case;        

根据传入的月份,判定月份所属的季节,1-3月份,为第一季度,4-6月份,为第二季度,7-9月份,为第三季度,10-12月份,为第四季度

While

有条件的循环控制语句,满足条件后,再执行循环体中的sql语句

先判定条件,如果为true,则执行逻辑,否则,不执行逻辑

while 条件 do
    sql逻辑
end while;    

计算从1累加到n的值,n为传入的参数

Repeat

满足条件时退出循环

先执行一次逻辑,然后判定逻辑是否满足,若满足,则退出;不满足,继续下一次

repeat
    sql逻辑
    until 条件
end repeat;    

Loop

loop实现简单的循环,如果不存在sql逻辑中增加退出循环的条件,可以用其来实现简单的死循环,可以配合以下两个语句使用

leave:配合循环使用,退出循环

iterate:必须在循环体中使用,作用是跳过当前循环剩下的语句,直接进入下一次循环

[begin_label:] loop
    sql逻辑
end loop [end_label];
leave label;退出指定标记的循环体
iterate label;直接进入下一次循环    

计算从1累加到n的值,n为传入的参数值

计算从1到n之间的偶数累加的值,n为传入的参数值

游标

用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理,游标的使用包括游标的声明,open,fetch和close,其语法分别如下

声明游标

declare 游标名称 cursor for 查询语句;

打开游标

open 游标名称;

获取游标记录

fetch 游标名称 into 变量[,变量];

关闭游标

close 游标名称;

如图会执行出错,但是u_address中是有数据的,原因在于while中的条件为true,表中的数据为空依然会继续执行

条件处理程序

可以用来定义在流程控制结构执行过程中遇到问题时相应的处理步骤,具体语法为:

declare handler_action handler for condition_value [,condition_value]... statement;

handler_action 
    continue:继续执行当前程序
    exit:终止执行当前程序
condition_value
    sqlstate sqlstate_value:状态码,如02000
    sqlwarning:所有以01开头的sqlstate代码的简写
    not found:所有以02开头的sqlstate代码的简写
    sqlexception:所有没有被sqlwarning或not found捕获的sqlstate代码的简写    

存储函数

是有返回值的存储过程,存储函数的参数只能是in类型,具体语法如下:

create function 存储函数名称([参数列表])
returns type [characteristic...]
begin 
    --sql语句
    return...;
end;    
characteristic说明:
deterministic:相同的输入参数总是产生相同的结果
no sql:不包含sql语句
reads sql data:包含读取数据的语句,但不包含写入数据的语句
从1到n累加和

;