当前位置:网站首页>MySQL-存储过程-函数-

MySQL-存储过程-函数-

2022-08-03 08:36:00 LXMXHJ

存储过程

概述

概念

  • 存储过程和函数定义:
    类似于java中的方法。
    一组预先编写好的SQL语句的集合,理解成批处理语句。

  • 好处:
    提高代码的重用性;简化操作;减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

创建

语法

create procedure 存储过程名(参数列表)
begin
	存储过程体(一组合法有效的SQL语句)
end

注意

  • 参数列表包含三部分
参数模式 参数名 参数类型
案例:
in stuname varchar(20);
  • 参数模式:
模式说明
in该参数可以作为输入,也就是该参数需要传入值(其中in可以省略)
out该参数可以作为输出,也就是该参数可以作为返回值
inout该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。
  • 如果存储过程体仅仅只有一句话,begin end可以省略
  • 存储过程体中的每条SQL语句的结尾要求必须加分号,存储过程的结尾可以使用delimiter重新设置
delimiter 结束标记
delimiter $

调用

语法

call 存储过程名(实参列表);

举例说明

# 调用in模式的参数
call sp1('值');

# 调用out模式的参数
set @name;
call sp1(@name);
select @name;

# 调用inout模式的参数
set @name =;
call sp1(@name);
select @name;

案例

  • 参数列表为空
    在这里插入图片描述
  • 创建带in模式参数的存储过程
    在这里插入图片描述
  • 创建带有out模式参数的存储过程
    在这里插入图片描述
  • 创建带有inout参数的存储过程
    在这里插入图片描述

删除

语法

drop procedure 存储过程名;

案例:只支持删除一个
在这里插入图片描述

查看

语法

show create procedure 存储过程名;

案例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

函数

概述

定义
一组预先编译好的SQL语句的集合,理解成批处理语句。

好处

提高代码的重用性。
简化操作。
减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率。

存储过程与函数区别

区别存储过程函数
返回值个数可以是0个或者多个有且仅有一个
操作适合批量插入、批量更新适合做处理后返回一个结果

创建

语法

create function 函数名(参数名 参数类型) returns 返回类型
begin
	函数体
end

注意

  • 参数列表—包含两部分:参数名、参数类型
  • 函数体—肯定有return语句,如果没有写会报错
    如果return语句没有放在函数体的最后也不报错,但不建议
  • 函数体仅有一句话,则可以省略begin end
  • 使用delimiter语句设置结束标记

调用

语法

select 函数名(参数列表);

查看

语法

show create function 函数名;

删除

语法

drop function 函数名;

案例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

原网站

版权声明
本文为[LXMXHJ]所创,转载请带上原文链接,感谢
https://blog.csdn.net/LXMXHJ/article/details/125478981