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

举报
王小王-123 发表于 2022/04/08 23:32:59 2022/04/08
【摘要】 MySQL存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数。 存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合。 存储函数与存储过程的区别 1.存储函数有且只有一个返回值,而存储过程可以有多个返回值,也可以没有返回值。 2.存储函数只能有输入参数,而且不能带in,...

MySQL存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数。

存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合。

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

1.存储函数有且只有一个返回值,而存储过程可以有多个返回值,也可以没有返回值。

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

3.存储过程中的语句功能更强大,存储过程可以实现很复杂的业务逻辑,而函数有很多限制,如不能在函数中使用insert,update,delete,create等语句;

4.存储函数只完成查询的工作,可接受输入参数并返回一个结果,也就是函数实现的功能针对性比较强。

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

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


  
  1. create function func_name ([param_name type[,...]])
  2. returns type
  3. [characteristic ...]
  4. begin
  5. routine_body
  6. end;

参数说明:
(1)func_name :存储函数的名称。
(2)param_name type:可选项,指定存储函数的参数。type参数用于指定存储函数的参数类型,该类型可以是MySQL数据库中所有支持的类型。
(3)RETURNS type:指定返回值的类型。
(4)characteristic:可选项,指定存储函数的特性。
(5)routine_body:SQL代码内容。


  
  1. create database mydb9_function;
  2. -- 导入测试数据
  3. use mydb9_function;
  4. set global log_bin_trust_function_creators=TRUE; -- 信任子程序的创建者
  5.  
  6. -- 创建存储函数-没有输输入参数
  7. drop function if exists myfunc1_emp;
  8.  
  9. delimiter $$
  10. create function myfunc1_emp() returns int
  11. begin
  12. declare cnt int default 0;
  13. select count(*) into cnt from emp;
  14. return cnt;
  15. end $$
  16. delimiter ;
  17. -- 调用存储函数
  18. select myfunc1_emp();

  
  1. -- 创建存储过程-有输入参数
  2.  
  3. drop function if exists myfunc2_emp;
  4. delimiter $$
  5. create function myfunc2_emp(in_empno int) returns varchar(50)
  6. begin
  7. declare out_name varchar(50);
  8. select ename into out_name from emp where empno = in_empno;
  9. return out_name;
  10. end $$
  11. delimiter ;
  12.  
  13.  
  14. select myfunc2_emp(1008);

每文一语

适合自己的才是最好的

文章来源: wxw-123.blog.csdn.net,作者:王小王-123,版权归原作者所有,如需转载,请联系作者。

原文链接:wxw-123.blog.csdn.net/article/details/123613963

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。