Mysql 存储过程

我们大家都知道MySQL 存储过程是从 MySQL 5.0 开始逐渐增加新的功能。存储过程在实际应用中也是优点大于缺点。不过最主要的还是执行效率和SQL 代码封装。特别是 SQL 代码封装功能,如果没有存储过程。网上一篇详细的解释 http://blog.sina.com.cn/s/blog_52d20fbf0100ofd5.html

在外部程序访问数据库时(例如 PHP),要组织很多 SQL 语句。

特别是业务逻辑复杂的时候,一大堆的 SQL 和条件夹杂在 PHP 代码中,让人不寒而栗。现在有了 MySQL 存储过程,业务逻辑可以封装存储过程中,这样不仅容易维护,而且执行效率也高。

一、MySQL 创建存储过程

“pr_add” 是个简单的 MySQL 存储过程,这个MySQL 存储过程有两个 int 类型的输入参数 “a”、“b”,返回这两个参数的和。

  1. drop procedure if exists pr_add;  

计算两个数之和

delimiter //
create procedure pr_add(a int,b int)   
begin   
declare c int;   
if a is null then   
set a = 0;   
end if;   
if b is null then   
set b = 0;   
end if;   
set c = a + b;   
select c as sum;   
/*   
return c;  
不能在 MySQL 存储过程中使用。return 只能出现在函数中。
*/   
end;

二、调用 MySQL 存储过程

  1. call pr_add(10, 20);  
  2. 输出结果为
    sum  
    30

     

执行 MySQL 存储过程,存储过程参数为 MySQL 用户变量。

  1. set @a = 10;   
  2. set @b = 20;   
  3. call pr_add(@a, @b);  

三、MySQL 存储过程特点

创建 MySQL 存储过程的简单语法为:

  1. create procedure 存储过程名字()   
  2. (   
  3. [in|out|inout] 参数 datatype   
  4. )   
  5. begin   
  6. MySQL 语句;   
  7. end;  

MySQL 存储过程参数如果不显式指定“in”、“out”、“inout”,则默认为“in”。习惯上,对于是“in” 的参数,我们都不会显式指定。

1. MySQL 存储过程名字后面的“()”是必须的,即使没有一个参数,也需要“()”

2. MySQL 存储过程参数,不能在参数名称前加“@”,如:“@a int”。下面的创建存储过程语法在 MySQL 中是错误的(在 SQL Server 中是正确的)。 MySQL 存储过程中的变量,不需要在变量名字前加“@”,虽然 MySQL 客户端用户变量要加个“@”。

  1. create procedure pr_add   
  2. (   
  3. @a int, -- 错误   
  4. b int -- 正确   
  5. )  

3. MySQL 存储过程的参数不能指定默认值。

4. MySQL 存储过程不需要在 procedure body 前面加 “as”。而 SQL Server 存储过程必须加 “as” 关键字。

  1. create procedure pr_add   
  2. (   
  3. a int,   
  4. b int   
  5. )   
  6. as -- 错误,MySQL 不需要 “as”   
  7. begin   
  8. mysql statement ...;   
  9. end;  

5. 如果 MySQL 存储过程中包含多条 MySQL 语句,则需要 begin end 关键字。

  1. create procedure pr_add   
  2. (   
  3. a int,   
  4. b int   
  5. )   
  6. begin   
  7. mysql statement 1 ...;   
  8. mysql statement 2 ...;   
  9. end;  

6. MySQL 存储过程中的每条语句的末尾,都要加上分号 “;”

  1. ...   
  2. declare c int;   
  3. if a is null then   
  4. set a = 0;   
  5. end if;   
  6. ...   
  7. end;  

7. MySQL 存储过程中的注释。

  1. /*   
  2. 这是个   
  3. 多行 MySQL 注释。   
  4. */   
  5. declare c int; -- 这是单行 MySQL 注释 (注意 -- 后至少要有一个空格)   
  6. if a is null then # 这也是个单行 MySQL 注释   
  7. set a = 0;   
  8. end if;   
  9. ...   
  10. end;  

8. 不能在 MySQL 存储过程中使用 “return” 关键字。

  1. set c = a + b;   
  2. select c as sum;   
  3. /*   
  4. return c; -- 不能在 MySQL 存储过程中使用。return 只能出现在函数中。   
  5. */   
  6. end;  

9. 调用 MySQL 存储过程时候,需要在过程名字后面加“()”,即使没有一个参数,也需要“()”

  1. call pr_no_param();  

10. 因为 MySQL 存储过程参数没有默认值,所以在调用 MySQL 存储过程时候,不能省略参数。可以用 null 来替代

存储函数与存储过程的区别

一、 存储函数有且只有一个返回值,而存储过程不能有返回值。

二、 函数只能有输入参数,而且不能带in, 而存储过程可以有多个in,out,inout参数。

三、 存储过程中的语句功能更强大,存储过程可以实现很复杂的业务逻辑,而函数有很多限制,如不能在函数中使用insert,update,delete,create等语句;存储函数只完成查询的工作,可接受输入参数并返回一个结果,也就是函数实现的功能针对性比较强。

四、 存储过程可以调用存储函数。但函数不能调用存储过程。

五、 存储过程一般是作为一个独立的部分来执行(call调用)。而函数可以作为查询语句的一个部分来调用。

 

存储函数的语法: 

  create function 函数([函数参数[,….]]) Returns 返回类型

  Begin

    If(

      Return (返回的数据)

    Else 

      Return (返回的数据)

    end if;

  end;

例如: create function count_news(hits int) returns int
  与存储过程返回参数不同的是存储函数在定义时没用直接声明哪个变量是返回参数,而只是使用了returns声明了返回参数所属的数据类型,返回参数是在函数体中使用return返回要返回的数据变量的形式来表示的。这就需要注意的是:
存储函数只支持输入参数,并且输入参数前没有IN或INOUT.

原文地址:https://www.cnblogs.com/xs-yqz/p/4963276.html