这篇“MySQL存储函数与存储过程的区别是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL存储函数与存储过程的区别是什么”文章吧。
MySQL存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数。
存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合。
存储函数与存储过程的区别
1.存储函数有且只有一个返回值,而存储过程可以有多个返回值,也可以没有返回值。
存储函数只能有输入参数,而且不能带in, 而存储过程可以有多个in,out,inout参数。
存储过程中的语句功能更强大,存储过程可以实现很复杂的业务逻辑,而函数有很多限制,如不能在函数中使用insert,update,delete,create等语句;
存储函数只完成查询的工作,可接受输入参数并返回一个结果,也就是函数实现的功能针对性比较强。
5.存储过程可以调用存储函数、但函数不能调用存储过程。
存储过程一般是作为一个独立的部分来执行(call调用)。而函数可以作为查询语句的一个部分来调用.
create function func_name ([param_name type[,...]])returns type[characteristic ...] begin routine_bodyend;
参数说明:
(1)func_name :存储函数的名称。
(2)param_name type:可选项,指定存储函数的参数。type参数用于指定存储函数的参数类型,该类型可以是MySQL数据库中所有支持的类型。
(3)RETURNS type:指定返回值的类型。
(4)characteristic:可选项,指定存储函数的特性。
(5)routine_body:SQL代码内容。
create database mydb9_function;-- 导入测试数据use mydb9_function;set global log_bin_trust_function_creators=TRUE; -- 信任子程序的创建者 -- 创建存储函数-没有输输入参数drop function if exists myfunc1_emp; delimiter $$create function myfunc1_emp() returns intbegin declare cnt int default 0; select count(*) into cnt from emp; return cnt;end $$delimiter ;-- 调用存储函数select myfunc1_emp();
-- 创建存储过程-有输入参数drop function if exists myfunc2_emp;delimiter $$create function myfunc2_emp(in_empno int) returns varchar(50)begin declare out_name varchar(50); select ename into out_name from emp where empno = in_empno; return out_name;end $$delimiter ;select myfunc2_emp(1008);
以上就是关于“MySQL存储函数与存储过程的区别是什么”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。