数据表的存储过程和函数介绍
文章目录
- 一、概述
- 二、创建存储过程
- 三、在创建过程中使用变量
- 四、光标的使用
- 五、流程控制的使用
- 六、查看和删除存储过程
一、概述
存储过程和函数是在数据库中定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句。存储过程和函数可以避免开发人员重复编写相同的SQL语句。而且。存储过程和函数是在MySQL服务器中存储和执行的。可以减少客户端和服务端的数据传输。
二、创建存储过程
创建存储过程和函数是指将经常使用的一组SQL语句组合在一起,并将这些SQL语句当作一个整体存储在MySQL服务器中。存储程序可以分为存储过程和函数。在MySQL中创建存储过程使用的语句CREATE PROCEDURE。其语法形式如下:
CREATE PROCEDURE procedure_name([proc_param[,...]]) routine_body
在上述语句中,参数procedure_name表示要创建的存储过程名字,参数proc_param表示存储过程的参数,参数routine_body表示存储过程的SQL语句代码,可以使用BEGIN…END来标志SQL语句的开始和结束。
**注意:**在具体创建存储过程时,存储过程名不能与已经存在的存储过程名重名。
proc_param中每个参数的语法形式如下:
在上述语句中,每个参数由三部分组成,分别为输入/输出类型、参数名和参数类型。其中,输入/输出类型有三种类型,分别为IN(表示输入类型)、OUT(表示输出类型)、INOUT(表示输入/输出类型)。param_name表示参数名;type表示参数类型,可以是MySQL软件所支持的任意一个数据类型。

三、在创建过程中使用变量
在存储过程和函数中,可以定义和使用变量。用户可以使用关键字DECLARE来定义变量。然后为变量赋值。这些变量的作用范围是在BEGIN…END程序段中。
1.定义变量
在MySQL中,可以使用DECLARE关键字来定义变量。定义变量的基本语法如下:
DECLARE var_name[,...] type [DEFAULT value]
其中关键字DECLARE是用来声明变量的;参数var_name是变量的名称,可以同时定义多个变量;参数type用来指定变量的类型;DEFAULT value子句将变量默认值设置为value,没有使用DEFAULT子句时,默认值为NULL。
定义变量cid,数据类型为INT类型,默认值为10,代码如下:
DECLARE cid INT DEFAULT 10;
2.为变量赋值
在MySQL中可以使用关键字SET来为变量赋值,SET语句的基本语法如下:
SET var_name=expr[,var_name=expr]...
其中,关键字SET用来为变量赋值;参数var_name是变量的名称;参数expr是赋值表达式。一个SET语句可以同时为多个变量赋值。各个变量的赋值语句之间用逗号隔开。
例如,将变量tmp_id赋值为88,代码如下:
SET tmp_id = 88;
在MySQL中,还可以使用SELECT…INFO语句为变量赋值。其基本语法如下:
SELECT col_name[,...] INFO var_name[,...] FROM table_name WHERE condition
其中,参数col_name表示查询的字段名称;参数var_name是变量的名称;参数table_name指表的名称;参数condition指查询条件。

四、光标的使用
查询语句可能查询出多条记录,在存储过程和函数中使用光标来逐条读取查询结果集中的记录。光标的使用包括声明光标、打开光标、使用光标和关闭光标。光标必须声明在处理程序之前,并且声明在变量和条件之后。
1.声明光标
在MySQL中,可以使用DECLARE关键字来声明光标,其基本语法如下:
DECLARE cursor_name CURSOR FOR select_statement;
其中参数cursor_name表示光标的名称;参数select_statement表示SELECT语句的内容。
2.打开光标
在MySQL中,使用关键字OPEN来打开光标,其基本语法如下:
OPEN cursor_name;
其中,参数cursor_name表示光标的名称。
3.使用光标
在MySQL中,使用关键字FETCH来使用光标,其基本语法如下:
FETCH cursor_name INTO var_name [,var_name...];
其中参数cursor_name表示光标的名称;参数var_name表示将光标中的SELECT语句查询出来的信息存入该参数中。var_name必须在声明光标之前定义好。
4.光标光标
在MySQL中,使用关键字CLOSE来关闭光标,其基本语法如下:
CLOSE cursor_name;
其中参数cursor_name表示光标的名称。


五、流程控制的使用
在存储过程和函数中,可以使用流程来控制语句的执行,在MySQL中,可以使用IF语句、CASE语句、LOOP语句、LEAVE语句,ITERATE语句、REPEAT语句和WHILE语句来进行流程控制。
1.IF语句
IF语句用来进行条件判断。根据条件执行不同的语句,其语法的基本形式如下:
IF search_condition THEN statement_list
[ELSEIF search_condition THEN statement_list]
...
[ELSE statement_list] END IF
参数search_condition表示条件判断语句;参数statement_list表示不同条件的执行语句。
下面是一个IF语句的示例,代码如下:
IF age > 20 THEN SET @count1 = @count1 + 1;ELSEIF age = 20 THEN @count2 = @count2 + 1;ELSE @count3 = @count3 + 1;
END IF;
该示例根据age与20的大小关系来执行不同的SET语句。如果age值大于20,将count1的值加1;如果age值等于20,就将count2的值加1;其他情况将count3的值加1。IF语句都需要使用END IF来结束。

2.CASE语句
CASE语句可实现比IF语句更复杂的条件判断,其语法的基本形式如下:
CASE case_value
WHEN when_value THEN statement_list
[WHEN when_value THEN statement_list]
[ELSE statement_list]
END CASE
其中,参数case_value表示条件判断的变量;参数when_value表示变量的取值;参数statement_list表示不同的when_value值的执行语句。
下面是一个CASE语句的示例。代码如下:
CASE levelWHEN 20 THEN SET attack = attack + 5;WHEN 30 THEN SET attack = attack + 10;WHEN 40 THEN SET attack = attack + 15;ELSE SET attack = attack + 1;
END CASE
当级别level值为20时,attack值加5;当级别level值为30时,attack值加10;当级别level值为40时。attack值加15;否则attack + 1。CASE语句使用END CASE结束。
3.LOOP语句
LOOP语句可以使某些特定的语句重复执行,实现一个简单的循环。LOOP语句本身没有停止循环,只有遇到LEAVE语句等才能停止循环。LOOP语句的语法形式如下:
[begin_label:] LOOP
statement_list
END LOOP [end_label]
其中,参数begin_label和参数end_label分别表示循环开始和结束的标志,这两个标志必须相同。而且都可以省略;参数statemeng_list表示需要循环执行的语句。
下面是一个LOOP语句的示例,代码如下:
ADD_num:LOOPSET @count = @count + 1;
END LOOP add_num;
该示例循环执行count加1的操作。因为没有跳出循环,这个循环成了一个死循环。LOOP循环都以END LOOP结束。
4.LEAVE语句
LEAVE语句主要用于跳出循环控制,其语法形式如下:
LEAVE label
其中,参数label表示循环的标志。
下面是一个LEAVE语句的示例,代码如下:
add_num:LOOPSET @count = @count + 1;IF @count = 100 THENLEAVE add_num;END IF;
END LOOP add_num;
该示例循环执行count值加1的操作。当count的值等于100时,LEAVE语句跳出循环。

5.ITERATE语句
ITERATE语句也是用来跳出循环的语句,但是ITERATE语句是跳出本次循环,然后直接进入下一次循环,ITERATE语句的语法形式如下:
ITERATE label
其中,参数label表示循环的标志。
下面是一个ITERATE语句的示例,代码如下:
add_num:LOOPset @count = @count +1;IF @count = 100 THENLEAVE add_num;ELSE IF MOD(@count, 3) = 0 thenITERATE add_num;select * from student;
END LOOP add_num;
该示例循环执行count加1的操作,count的值为100时结束循环,如果count的值能够整除3,就跳出本次循环,不再执行下面的SELECT语句。
6.REPEAT语句
REPEAT语句是有条件控制的循环语句,当满足特定条件时,就会跳出循环语句。REPEAT语句的基本语法形式如下:
[begin_label:] REPEATUNTIL search_conditionEND REPEAT [end_label]
其中,参数statement_list表示循环的执行语句;参数search_condition表示结束循环的条件,满足该条件时循环结束。
下面是一个REPEAT语句的示例,代码如下:
REPEATSET @count=@count+1;UNTIL @count=100
END REPEAT;
该示例循环执行count加1的操作,count值为100时结束循环。REPEAT循环都用END REPEAT结束。
7.WHILE语句
WHILE语句也是有条件控制的循环语句,但WHILE语句和REPEAT语句是不一样的。WHILE语句是当满足条件时执行循环内的语句。WHILE语句的基本语法形式如下:
[begin_label:] WHILE search_condition DOstatement_list
END WHILE [end_label]
其中,参数statement_condition表示循环执行的条件,满足该条件时循环执行;参数statement_list表示循环的执行语句。
下面是一个WHILE语句的示例。代码如下:
WHILE @count<100 DOSET @count = @count + 1;
END WHILE;
六、查看和删除存储过程
存储过程创建以后,用户可以通过SHOW STATUS语句来查看存储过程的状态,也可以通过SHOW CREATE语句来查看存储过程的定义。用户也可以通过查询information_schema数据库下的Routines表来查看存储过程的信息。
1.SHOW STATUS语句查看存储过程
在MySQL中,可以通过SHOW STATUS语句查看存储过程的状态。其基本语法形式如下:
SHOW PROCEDURE STATUS [like 'pattern'];
其中,参数PROCEDURE表示查询存储过程;参数LIKE 'pattern’用来匹配存储过程的名称。
2.SHOW CREATE语句查看存储过程的定义
在MySQL中,可以通过SHOW CREATE 语句查看存储过程的状态,语法形式如下:
SHOW CREATE PROCEDURE proc_name
其中,参数PROCEDURE表示查询存储过程;参数proc_name表示存储过程的名称。
3.information_schema.Routine表中查看存储过程的信息
存储过程和函数的信息存储在information_schema数据库下的Routines表中。可以通过查询该表的记录来查询存储过程和函数的信息。其基本语法形式如下:
SELECT * FROM information_schema.Routines WHERE ROUTINE_NAME = 'proc_name';
其中,字段ROUTINE_NAME中存储的是存储过程和函数的列名称;参数proc_name表示存储过程或函数的名称。
4.存储过程的删除
在MySQL中删除存储过程通过SQL语句DROP完成:
DROP PROCEDURE proc_name;
在上述语句中,关键字DROP PROCEDURE用来实现删除存储过程,参数proc_name表示所要删除的存储过程名称。
相关文章:
数据表的存储过程和函数介绍
文章目录 一、概述二、创建存储过程三、在创建过程中使用变量四、光标的使用五、流程控制的使用六、查看和删除存储过程 一、概述 存储过程和函数是在数据库中定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句。存储过程和函数可…...
为AI聊天工具添加一个知识系统 之117 详细设计之58 思维导图及观察者效应 之2 概念全景图
(说明:本文和上一篇问题基本相同,但换了一个模型 deepseek-r1) Q1227、在提出项目“为使用AI聊天工具的聊天者加挂一个专属的知识系统”后,我们已经进行了了大量的讨论-持续了近三个月了。这些讨论整体淋漓尽致体现了…...
Error [ERR_REQUIRE_ESM]: require() of ES Module
报错信息: 【报错】Message.js 导入方式不对,用的是 ES Moudle 的语法,提示使用 import 引入文件 项目开发没有用到 js-message 依赖,是 node-ipc 依赖中用到的 js-message 依赖, node-ipc 中限制 js-message 版本&a…...
GStreamer源码安装1.24版本
从官网下载 1.24的源码包 https://gitlab.freedesktop.org/gstreamer/gstreamer/-/tree/1.24?ref_typeheads#getting-started ,尝试过使用git clone 的方式,但速度贼慢,就选择了下载源码包的方式安装依赖 sudo apt install libssl-dev g me…...
从CNN到Transformer:遥感影像目标检测的未来趋势
文章目录 前言专题一、深度卷积网络知识专题二、PyTorch应用与实践(遥感图像场景分类)专题三、卷积神经网络实践与遥感影像目标检测专题四、卷积神经网络的遥感影像目标检测任务案例【FasterRCNN】专题五、Transformer与遥感影像目标检测专题六、Transfo…...
从 x86 到 ARM64:CPU 架构的进化与未来
在计算机发展的历史长河中,x86、x64 和 ARM64 这三大主流 CPU 架构各自书写了辉煌的篇章。它们不仅代表了技术的进步,更承载着无数创新者的梦想与努力。 x86:从 16 位到 32 位的辉煌之路 诞生与崛起 1978 年,英特尔(…...
Java数据结构第十二期:走进二叉树的奇妙世界(一)
专栏:数据结构(Java版) 个人主页:手握风云 目录 一、树型结构 1.1. 树的定义 1.2. 树的基本概念 1.3. 树的表示形式 二、二叉树 2.1. 概念 2.2. 两种特殊的二叉树 2.3. 二叉树的性质 2.4. 二叉树的存储 三、二叉树的基本操作 一、树型结构 1.…...
基于ffmpeg+openGL ES实现的视频编辑工具-添加贴纸(八)
在当下丰富多元的音视频编辑应用领域,添加贴纸已然成为一项广受欢迎的功能,它能够为音视频作品注入独特的趣味与创意元素。本文将深入探究音视频添加贴纸背后所涉及的技术原理与实现路径。 一、技术原理概述 音视频从本质上来说,是由一系列连续的图像帧(针对视频部分)以…...
【AI时代】基于AnythingLLM+ Ollama + DeepSeek 搭建本地知识库
一、本地安装Ollama及DeepSeek 参考教程: https://blog.csdn.net/Bjxhub/article/details/145536134 二、下载并安装AnythingLLM AnythingLLM下载地址: https://anythingllm.com/ 傻瓜式安装即可 可以自定义安装路径。三、配置AnythingLLM并使用 3.…...
leetcode刷题记录(一百一十五)——64. 最小路径和
(一)问题描述 64. 最小路径和 - 力扣(LeetCode)64. 最小路径和 - 给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下…...
UE5 编辑器辅助/加强 插件搜集
1. Actor Locker 地址:https://www.fab.com/listings/ec26ac5e-4720-467c-a3a6-b5103b6b74d0 使用说明:https://github.com/Gradess2019/ActorLocker 支持:5.0 – 5.5 简单的编辑器扩展。它允许你通过世界轮廓窗口/热键/上下文菜单在编辑器视…...
怎么在Github上readme文件里面怎么插入图片?
环境: Github 问题描述: 怎么在Github上readme文件里面怎么插入图片? https://github.com/latiaoge/AI-Sphere-Butler/tree/master 解决方案: 1.相对路径引用 上传图片到仓库 将图片文件(如 .png/.jpgÿ…...
什么是矩阵账号?如何高效运营tiktok矩阵账号
…...
SpringSecurity初始化的本质
一、对SpringSecurity初始化的几个疑问 通过前面第一次请求访问的分析我们明白了一个请求就来后的具体处理流程 对于一个请求到来后会通过FilterChainProxy来匹配一个对应的过滤器链来处理该请求。那么这里我们就有几个疑惑。 FilterChainProxy什么时候创建的?过滤器链和对应的…...
自注意力机制和CNN的区别
CNN:一种只能在固定感受野范围内进行关注的自注意力机制。CNN是自注意力的简化版本。自注意力:具有可学习感受野的CNN。自注意力是CNN的复杂形态,是更灵活的CNN,经过某些设计就可以变为CNN。 越灵活、越大的模型,需要…...
Vue 不同大版本与 Node.js 版本匹配的详细参数
Vue 2.x 与 Node.js 版本匹配: Vue 2.x 细分版本建议 Node.js 版本理由支持状态2.0 - 2.610.x - 14.x这些 Node.js 版本在 Vue 2.x 早期开发和维护阶段广泛使用,能提供稳定运行环境,适配当时常用构建工具和依赖包Node.js 10.x 维护期已结束;…...
本地部署DeepSeek-R1模型教程
文章目录 第一步:安装运行框架 哈喽各位小伙伴们,最近deepseek非常的火,不过因为全球访问量剧增经常会导致deepseek的服务器繁忙,如果想要稳定使用就得靠本地部署了,不仅可以稳定使用还能保护数据隐私,今天…...
设计心得——解耦的实现技术
一、说明 在前面的“设计心得——解耦”中,对解耦进行了高层次的抽象说明。本篇则对在实践中常用的解耦技术进行逐一分析说明,以期为开发者能更从理论到实践搭建一个桥梁。至于大家能够如何更好的在自己的项目中进行解耦的实践,就需要不断的…...
k2路由器登录校园网
教程1刷入Breed,并手动刷入Padavan固件:斐讯K1、K2、K2P 刷机、刷入Breed 辅助工具 | tb (tbvv.net) Padavan下载网址: 我用的是: Padavan 登录的网址是 192.168.123.1 Padavan配置教程: 先用网线连上校园网&#…...
基于Springboot学生宿舍水电信息管理系统【附源码】
基于Springboot学生宿舍水电信息管理系统 效果如下: 系统登陆页面 系统用户首页 用电信息页面 公告信息页面 管理员主页面 用水信息管理页面 公告信息页面 用户用电统计页面 研究背景 随着高校后勤管理信息化的不断推进,学生宿舍水电管理作为高校后勤…...
手机怎样玩电脑游戏?
如果您正在寻找一款能够实现手机远程控制电脑玩游戏的软件,本文推荐远程看看软件。这款软件不仅支持手机远程控制电脑,还具备电脑与电脑之间的多端互控功能,您能够随时随地畅玩游戏,享受无缝的游戏体验。此外,远程看看…...
【Linux网络】认识协议(TCP/UDP)、Mac/IP地址和端口号、网络字节序、socket套接字
⭐️个人主页:小羊 ⭐️所属专栏:Linux 很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~ 目录 1、初识协议2、UDP、TCP3、Mac、IP地址4、端口号5、网络字节序6、socket 1、初识协议 协议就是一种约定。如何让不同厂商生产的计…...
【软考知识】奇偶校验码,循环冗余码,海明码介绍
文章目录 **1. 奇偶校验码 (Parity Check Code)****基本原理****算法流程****优点与缺点****应用场景** **2. 循环冗余码 (Cyclic Redundancy Check, CRC)****基本原理****算法流程****例子****优点与缺点****应用场景** **3. 海明码 (Hamming Code)****基本原理****算法流程**…...
SOME/IP--协议英文原文讲解10
前言 SOME/IP协议越来越多的用于汽车电子行业中,关于协议详细完全的中文资料却没有,所以我将结合工作经验并对照英文原版协议做一系列的文章。基本分三大块: 1. SOME/IP协议讲解 2. SOME/IP-SD协议讲解 3. python/C举例调试讲解 4.2.2 Req…...
前端面试-网络协议篇
1.http网络协议中post和get有什么区别 在HTTP网络协议中,POST和GET主要有以下区别: 参数传递方式: GET:参数附加在URL后面,如example.com?key1value1&key2value2 。POST:参数放在HTTP请求体中。 数据…...
音视频入门基础:RTP专题(10)——FFmpeg源码中,解析RTP header的实现
一、引言 由《音视频入门基础:RTP专题(9)——FFmpeg接收RTP流的原理和内部实现》可以知道,FFmpeg接收RTP流时,其源码内部会调用rtp_read函数。而rtp_read函数内部会通过recvfrom函数接收基于UDP的RTP音视频数据。一般…...
1.1 go环境搭建及基本使用
golang下载地址: Download and install - The Go Programming Language (google.cn) 验证安装是否成功: go version 查看go环境 go env 注意:Go1.11版本之后无需手动配置环境变量,使用go mod 管理项目,也不需要把项目放到GO…...
Flask flash() 消息示例
目录 安装 Flask 入门:Flask flash() 基本示例 进阶:使用 Flask-WTF Flash 登录结果消息 详解:get_flashed_messages() 详解:flash() 消息的完整生命周期 Flask 提供 flash() 用于向 用户传递临时消息,通常用于: • 表单提交成功或失败 • 用户登录、注册、退出提…...
Gemini 2.0助力科学突破,AI联合科学家系统登场
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
京东外卖骑手全部缴纳五险一金
刘强东这步棋,直击700万骑手软肋? 今天,京东突然甩出一张底牌:自2025年3月1日起,外卖全职骑手全员缴纳五险一金,兼职骑手配套意外医疗双保险。 消息一出,直接炸了外卖江湖。要知道,…...
