当前位置:网站首页>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 ] <函数名>
边栏推荐
- 深蓝学院-视觉SLAM十四讲-第七章作业
- Location、navigator和History对象
- 吴恩达机器学习系列课程笔记——第十三章:聚类(Clustering)
- 温暖的世界
- 科研笔记(五) SLAC WiFi Fingerprint+ Step counter融合定位
- How to save a section of pages in a PDF as a new PDF file
- 日本痴汉打赏女主播1.5亿,结果。。。
- 面试官:大量请求 Redis 不存在的数据,从而打倒数据库,有什么方案?
- Qt编写物联网管理平台49-设备模拟工具
- 如何让固定点的监控设备在EasyCVR平台GIS电子地图上显示地理位置?
猜你喜欢
随机推荐
The CCF brush topic tour - the first topic
Qt编写物联网管理平台49-设备模拟工具
无主复制系统(1)-节点故障时写DB
计算属性的学习
Arduino框架下ESP32重启原因串口信息输出示例
侦听器watch及其和计算属性、methods方法的总结
offset、client 和 scroll
吴恩达机器学习系列课程笔记——第七章:正则化(Regularization)
Promise
Zabbix删除一些大表历史数据脚本
力扣 剑指 Offer 56 - I. 数组中数字出现的次数
【学习笔记】如何打造运维组织架构
el-dropdown(下拉菜单)的入门学习
Deep Blue Academy - 14 Lectures on Visual SLAM - Chapter 7 Homework
Batch normalization (BN) based on deep learning
ADSP21489数据手册表摘要
【FreeRTOS】12 任务通知——更省资源的同步方式
Excel skills daquan
三维目标检测之OpenPCDet环境配置及demo测试
Your device is corrupt. It cant‘t be trusted and may not work propely.