当前位置:网站首页>MySQL存储函数详解
MySQL存储函数详解
2022-08-02 03:53:00 【ahyo】
存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合。存储函数可以通过 return 语句返回函数值,主要用于计算并返回一个值。而存储过程没有直接返回值,主要用于执行操作。
在 MySQL 中,使用 CREATE FUNCTION 语句来创建存储函数,其语法形式如下:
CREATE FUNCTION sp_name ([func_parameter[...]])
RETURNS type
[characteristic ...] routine_body
其中:
sp_name 参数:表示存储函数的名称;
func_parameter:表示存储函数的参数列表;
RETURNS type:指定返回值的类型;
characteristic 参数:指定存储函数的特性,该参数的取值与存储过程是一样的;
routine_body 参数:表示 SQL 代码的内容,可以用 BEGIN...END 来标示 SQL 代码的开始和结束。
注意:在具体创建函数时,函数名不能与已经存在的函数名重名。除了上述要求外,推荐函数名命名(标识符)为 function_xxx 或者 func_xxx。
func_parameter 可以由多个参数组成,其中每个参数由参数名称和参数类型组成,其形式如下:
[IN | OUT | INOUT] param_name type;
其中:
IN 表示输入参数,OUT 表示输出参数,INOUT 表示既可以输入也可以输出;
param_name 参数是存储函数的参数名称;
type 参数指定存储函数的参数类型,该类型可以是 MySQL 数据库的任意数据类型。
由于存储函数和存储过程的查看、修改、删除等操作几乎相同,所以我们不再详细讲解如何操作存储函数了。
查看存储函数的语法如下:
SHOW FUNCTION STATUS LIKE 存储函数名;
SHOW CREATE FUNCTION 存储函数名;
SELECT * FROM information_schema.Routines WHERE ROUTINE_NAME=存储函数名;
可以发现,操作存储函数和操作存储过程不同的是将 PROCEDURE 替换成了 FUNCTION。同样,修改存储函数的语法如下:
ALTER FUNCTION 存储函数名 [ 特征 … ]
存储函数的特征与存储过程的基本一样。
删除存储过程的语法如下:
DROP FUNCTION [ IF EXISTS ] <函数名>
边栏推荐
猜你喜欢
随机推荐
数据可视化之百变柱状图
Research Notes (6) Indoor Path Planning Method Based on Environment Perception
吴恩达机器学习系列课程笔记——第六章:逻辑回归(Logistic Regression)
复制延迟案例(3)-单调读
nr部分计算
3D目标检测之数据集
Deep Blue Academy-Visual SLAM Lecture 14-Chapter 6 Homework
Transfer of UKlog.dat and QQ, WeChat files
RuoYi-App启动教程
数据复制系统设计(3)-配置新的从节点及故障切换
盒子移动和滚动加载效果练习
面试官:大量请求 Redis 不存在的数据,从而打倒数据库,有什么方案?
Andrew Ng's Machine Learning Series Course Notes - Chapter 18: Application Example: Image Text Recognition (Application Example: Photo OCR)
this指向问题
多主复制下处理写冲突(1)-同步与异步冲突检测及避免冲突
无主复制系统(2)-读写quorum
Jetson Nano 2GB Developer Kit 安装说明
Arduino框架下ESP32重启原因串口信息输出示例
如何评价最近爆红的FastAPI?
OpenPCDet environment configuration of 3 d object detection and demo test









