MySQL存储过程简介

1、存储过程前端

存储过程是在大型数据库系统中一组为了完成特定功能的SQL语句集,存储在数据库中。存储过程通过第一次编译后,再次调用不须要编译,用户能够经过指定的存储过程名和给出一些存储过程定义的参数来使用它。存储过程就是为之后使用而保存的一条或多条SQL语句,我的理解跟函数相似,通常用的较少。mysql

好处:sql

  1. 经过把处理封装在一个易用的单元中,能够简化复杂的操做。
    2.不须要反复创建一系列的处理步骤,于是保证了数据的一致性。
    3.简化了对变更的管理,这一点的延伸就是安全性。
    4.存储过程一般以编译过的形式存储,因此DBMS处理命令所需的工做量少,提升了性能。

缺点:数据库

1.可移植性差
2.对于简单的SQL语句,存储过程没什么优点
4.若是只有一个用户使用数据库,那么存储过程对安全也没什么影响
5.团队开发时须要先统一标准,不然后期维护成本大
6.在大并发量访问的状况下,不宜写过多涉及运算的存储过程
7.业务逻辑复杂时,特别是涉及到对很大的表进行操做的时候,不如在前端先简化业务逻辑安全

2、存储过程语法格式并发

通常形式ide

create procedure [过程名]([in|out|inout] [参数名] [参数类型],...)
begin
    [SQL语句集;]
end

在定义参数部分时in表示传入参数,读取外部变量值赋给内部参数,但内部参数的做用域仅限存储过程;out表示传出参数,将内部参数传递到外部变量;inout既有in的功能,又用out的功能,属于in与out的结合体。在都不写的状况下,默认使用in选项
可是,因为SQL语句集部分同样使用的是分号(;)做为分隔符,因此要在建立存储过程前使用delimiter从新定义分隔符,并在建立完成后将分隔符还原。delimiter [新分隔符]函数

完整格式oop

delimiter [新分隔符]
create procedure [过程名]([in|out|inout] [参数名] [参数类型],...)
begin
    SQL语句集;         
end[新分隔符]
delimiter;

3、存储过程建立举例说明:性能

1.建立单条SQL存储过程select_id(),(没什么实际意义,仅仅举例)

delimiter //
create procedure select_id(inout id_inout int)
begin
    select user_id from user where user_id=id_inout;        
end//
delimiter;
##建立存储过程select_id()

2.建立好存储过程select_id()后,会保存在数据库中。若是创同名的存储过程会报错,若要建立相同名称的存储过程,须要删除后方可建立。

PROCEDURE select_id already exists
  1. 建立多条SQL存储过程select_ids()
delimiter $$
create procedure select_ids()
begin
    select user_id from user;       
        select customer_id from user;       
end$$
delimiter;

4、调用存储过程

调用存储过程很简单,call [过程名](@[外部参数名],.

调用select_id()

set@user_id=62356;
call select_id(@user_id);
或者
call select_id(62356)

调用select_ids()

call select_ids();

5、查看存储过程

1.查看存储过程具体内容

show create procedure test.select_id;

2.查看存储过程状态

show PROCEDURE status;

6、删除存储过程

drop procedure [过程名];

drop procedure test.select_id;

7、SQL语句集延伸说明

1)定义存储过程的内部变量

  定义变量语句:declare [变量名,...] [变量类型] [default 默认值];

  赋值语句:set [变量名]=[表达式];

  能够一次定义多个同类型的变量,而且设置初始值。

2)多层嵌套

mysql> delimiter //
mysql> create procedure select3()
    -> begin
    -> declare name varchar(20) default '学生';
    -> select name;
    -> begin
    -> declare name varchar(20) default '老师';
    -> select name;
    -> end;
    -> end //
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;

3)条件语句

if语句

if [判断语句] then
[执行内容]
end if;

if [判断语句] then
[执行内容]
else
[执行内容]
end if;

case语句

case [变量名]
when [值] then
[执行内容]
when [值] then
[执行内容]
...
else
[执行内容]
end case;

循环语句

while语句,先判断后运行

while [判断语句] do
[执行内容]
end while
mysql> create procedure `while`(in num int)
    -> begin
    -> declare var int;
    -> set var=0;
    -> while var<num do
    -> set var=var+1;
    -> end while;
    -> select var;
    -> end //

repeat语句,先运行后判断

repeat
[执行内容]
until [判断语句]
end repeat;
mysql> create procedure `repeat`(in num int)
    -> begin
    -> declare var int;
    -> set var=0;
    -> repeat
    -> set var=var+2;
    -> until var>num
    -> end repeat;
    -> select var;
    -> end //

loop语句,运行直到遇到leave

[标签名]:loop
[执行内容]
leave [标签名]
[执行内容]
end loop;
mysql> create procedure `loop`(in num int)
    -> begin
    -> declare var int;
    -> set var=0;
    -> label1:loop
    -> set var=var+2;
    -> if var>num then
    -> leave label1;
    -> end if;
    -> end loop;
    -> select var;
    -> end //
相关文章
相关标签/搜索