Mysql存储过程(附案例)

news2025/5/18 3:57:38


文章目录

  • 存储过程概述
  • 1、基本语法
  • 2、变量
    • ①、系统变量
    • ②、用户自定义变量
    • ③、局部变量
  • 3、流程控制语句
    • ①、if语句
    • ②、参数
    • ③、case语句
    • ④、while语句
    • ⑤、repeat语句
    • ⑥、loop语句
    • ⑦、cursor游标
    • ⑧、handler
  • 4、存储函数

存储过程概述

存储过程是事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,提高数据处理的效率

存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

优点:

  1. 减少网络传输:在数据库端执行,降低应用服务器与数据库间的数据交互

  2. 性能提升:预编译减少了重复解析和优化,提高执行效率

  3. 简化开发:封装复杂逻辑,减少应用层代码量,便于调用

1、基本语法

  • 创建:
CREATE PROCEDURE 存储过程名称 ([参数列表]) BEGIN -- SQL语句 END;

举例:

-- 创建
CREATE PROCEDURE p1()
BEGIN

    SELECT COUNT(*) FROM student;

END

运行结果:
可以看到在functions下多了一个p1函数
在这里插入图片描述

  • 调用:
CALL 存储名称 ([参数]);

​举例:

CALL p1();

运行结果:
在这里插入图片描述

  • 查看
SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA = 'xxx'; -- 查询指定数据库的存储过程及状态信息
SHOW CREATE PROCEDURE 存储过程名称; -- 查询某个存储过程的定义

举例:

-- 查询指定数据库的存储过程及状态信息
SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA = 'school_db';

-- 查询某个存储过程的定义
SHOW CREATE PROCEDURE p1;

运行结果:

分别是两条语句的运行结果:
在这里插入图片描述
在这里插入图片描述

  • 删除
DROP PROCEDURE [IF EXISTS] 存储过程名称;

举例:
这样就删除成功了:

DROP PROCEDURE p1;

2、变量

①、系统变量

系统变量由Mysql服务器提供,不由用户定义,属于服务器层面,分为全局变量与会话变量。

全局变量:无论开多少个会话,变量值都是一样的,
会话变量:只在当前会话生效的变量。

在这里插入图片描述

像在navicat中,我们点击创建这三个query,就是三个不同的会话

查看语句:

-- 查看会话变量
SHOW SESSION VARIABLES;
-- 查看全局变量
SHOW GLOBAL VARIABLES;

-- 模糊查询
SHOW SESSION VARIABLES like 'auto%';
SHOW GLOBAL VARIABLES like 'auto%';

-- 直接选择具体的变量
SELECT @@global.autocommit;

查询结果:

在这里插入图片描述
变量可以看到有很多。

模糊查询结果:
在这里插入图片描述
具体查询结果:
在这里插入图片描述
更改语句:

-- 设置会话变量
SET SESSION autocommit = 0;
-- 设置全局变量
SET GLOBAL autocommit = 0;

②、用户自定义变量

用户定义变量是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用“@变量名”使用就可以。其作用域为当前连接。

使用方式:

-- 设置变量

SET @user_name := 'zhangsan';

select COUNT(*) into @num from student;

-- 使用变量

SELECT @num, @user_name;

注意点:赋值时使用 := 来赋值,然后赋值的话,也可以将查询的结果赋值给一个变量,如第二条查询语句。最后如果要查看自定义变量则使用最后一条的语法查询,查询结果如下:
在这里插入图片描述

③、局部变量

局部变量是根据需要定义的在局部生效的变量,访问之前,需要DECLARE声明。可用作存储过程中的局部变量和输入参数,局部变量的范围是在其声明的BEGIN … END块

使用方式:

CREATE PROCEDURE p2()
BEGIN
    -- 局部变量定义,前面为变量名,后面为变量类型,如int、varchar等。
    DECLARE stu_count int;
    -- 对变量赋值
    select COUNT(*) INTO stu_count from student;
    -- 查询变量
    select stu_count;
END

-- 调用存储过程
CALL p2();

调用结果:
在这里插入图片描述

3、流程控制语句

这部分其实和编程语言的流程控制基本相同,分支、循环,传参等,我们直接实战来演示。

①、if语句

根据分数判断是否合格。

-- if
CREATE PROCEDURE p3()
BEGIN
    DECLARE score INT DEFAULT 58;
    DECLARE result VARCHAR(10);
    -- if语句使用
    IF score >= 85 THEN
      SET result = '优秀';
    ELSEIF score >= 60 THEN
      SET result = '合格';
    ELSE
      SET result = '不合格';
    end IF;
    -- 查询结果
    SELECT result;
END
-- 调用流程
CALL p3();

运行结果:
在这里插入图片描述

②、参数

只需要知道三个声名参数的方法,分别是in、out、inout。

in用来声名输入参数,out用来声名输出参数,输出参数一般由一个变量来接收。

-- 参数
-- in表示声名输入参数,out表示声名返回结果
CREATE PROCEDURE p4(in score INT, out result VARCHAR(10))
BEGIN
    -- if语句使用
    IF score >= 85 THEN
      SET result = '优秀';
    ELSEIF score >= 60 THEN
      SET result = '合格';
    ELSE
      SET result = '不合格';
    end IF;
END
-- 调用过程
CALL p4(58, @result);

SELECT @result;

查询结果:
在这里插入图片描述

inout表明输入和输出都是同一个变量。

-- 将数字换成百分制的。
CREATE PROCEDURE p5(inout score DOUBLE)
BEGIN
   set score := score * 0.01
END;

set @SCORE = 78
-- 调用过程
CALL p5(@SCORE);

SELECT @SCORE;

运行结果:
在这里插入图片描述

③、case语句

根据月份判断第几季度。

-- case语句
CREATE PROCEDURE p6(in month INT)
BEGIN
    declare result VARCHAR(10);
   case
      when month >= 1 and month <= 3 then
        set result := '第一季度';
      when month >= 4 and month <= 6 then
        set result := '第二季度';
      when month >= 7 and month <= 9 then
        set result := '第三季度';
      when month >= 10 and month <= 12 then
        set result := '第四季度';
      else 
        set result := '非法参数';
    end case;
   
   select result;
END;


CALL p6(7);

运行结果:
在这里插入图片描述

④、while语句

求n到1的累加值。

CREATE PROCEDURE p7(in n INT)
BEGIN
    declare total INT DEFAULT 0;
    
    while n>0 do
        set total := total + n;
        set n := n - 1;
    end while;
    
    select total;
END;


CALL p7(10);

运行结果:
在这里插入图片描述

⑤、repeat语句

repeat是有条件的循环退出语句,类似c语言的do while语句

CREATE PROCEDURE p8(in n INT)
BEGIN
    declare total INT DEFAULT 0;
    
    repeat
        set total := total + n;
        set n := n - 1;
    until n <= 0
    end repeat;
    
    select total;
END;


CALL p8(10);

运行结果:
在这里插入图片描述

⑥、loop语句

里面注意需要给loop代码命个名,退出循环需要指定loop的名称。 leave等同于c语言中的break, iterate 效果等同于c语言中的continue

需求:从n 到 1中所有偶数相加的和

CREATE PROCEDURE p9(in n INT)
BEGIN
    declare total INT DEFAULT 0;
    
    sum:loop
        
        if n<=0 then
            leave sum;
        end if;
        
        if n%2=1 then
          set n := n - 1;
          iterate sum;
        end if;
        
        set total := total + n;
        set n := n - 1;
    end loop sum;
    
    select total;
END;

CALL p9(10);

运行结果:
在这里插入图片描述

⑦、cursor游标

游标 (CURSOR) 是用来存储查询结果集的游标类型,在存储过程和函数中可以使用游标来循环处理查询结果集中的每行记录。

游标可以存储sql查询的结果集合,而之前的参数只能传单行单列的数据。

声明游标:

DECLARE 游标名称 CURSOR FOR 查询语句;

打开游标:

OPEN 游标名称;

获取游标记录:

FETCH 游标名称 INTO 变量[变量];

关闭游标:

CLOSE 游标名称;

需求:将查询到的数据,存储到新表tb_user_pro中,游标语法如下:

CREATE PROCEDURE p10(in uid INT)
BEGIN
    -- 定义游标与变量
    declare u_name varchar(50);
    declare u_gender varchar(50);
    declare u_cursor cursor for select stu_name,gender from student where stu_id <= uid;
    
    
    -- 创建测试表
    create table if not exists tb_user_pro(
        id int PRIMARY key auto_increment,
        name2 VARCHAR(50),
        gender VARCHAR(50)
    );
    
    -- 开启游标
    open u_cursor; 
    
    WHile true do
        fetch u_cursor into u_name, u_gender; -- 获取游标中的数据并赋值给变量
        insert into tb_user_pro(name2, gender) VALUES (u_name, u_gender); -- 执行插入语句
    end while;
    
    -- 关闭游标
    close u_cursor;
END;

CALL p10(3);

运行结果:
在这里插入图片描述

可以看到,我们成功完成了功能,但是在执行的时候,有一些问题,在while true的时候,我们没有设置跳出循环的逻辑,导致结果正确,但执行会报错:
在这里插入图片描述

⑧、handler

条件处理程序 (Handler) 可以用来定义在流程控制结构过程中遇到问题时相应的处理步骤。具体语法为:

DECLARE handler_action HANDLER FOR condition_value [condition_value]... statement;

handler_action
CONTINUE: 继续执行当前程序
EXIT: 终止执行当前程序

condition_value
SQLSTATE sqlstate_value: 状态码,如 02000
SQLWARNING: 所有以01开头的SQLSTATE代码的警告
NOT FOUND: 所有以02开头的SQLSTATE代码的警告

SQLEXCEPTION: 所有没有被SQLWARNING 或 NOT FOUND捕获的SQLSTATE代码的警告

这里我们直接基于上一个案例来解释语法怎么用

我们在上一个案例的PROCEDURE中定义一个条件处理程序,在报错时就会执行这个程序:

-- exit表示退出程序,
-- SQLSTATE '02000' 等价于 not found 
-- 该程序最后执行的语句为:close u_cursor
declare exit handler for SQLSTATE '02000' close u_cursor;

最后运行的时候,发现程序就不再报错了,功能也正常了。

4、存储函数

存储函数是否有可能返回值的存储过程,存储函数的参数只能是IN类型的。具体语法如下:

CREATE FUNCTION 存储函数名称( [参数列表] )
RETURNS type [characteristic …]
BEGIN
    -- SQL语句
    RETURN;
END;

characteristic说明:

DETERMINISTIC: 相同的输入参数总是产生相同的结果
NO SQL: 不包含SQL语句。
READS SQL DATA: 包含读取数据的语句,但不包含写入数据的语句。

举例说明,
功能:实现从n到1的累加:

create function fun1(n INT)
-- 必须指定返回类型 和 characteristic
returns int DETERMINISTIC

BEGIN
    declare total INT default 0;
    
    while n > 0 do
      set total := total + n;
      set n := n - 1;
    end while;
    
    return total;
END;

select fun1(100)

运行结果:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2378211.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Web应用】Vue 项目前端项目文件夹和文件介绍

文章目录 ⭐前言⭐一、文件夹介绍&#x1f31f;1、.idea&#x1f31f;2、bin&#x1f31f;3、build&#x1f31f;4、node_modules&#x1f31f;5、public&#x1f31f;6、src ⭐二、文件介绍&#x1f31f;1、.editorconfig&#x1f31f;2、.env.development、.env.production、…

Stratix 10 FPGA DDR4 选型

文章目录 前言DDR3 和 DDR4 的区别Micron 8Gb DDR4 规格书详解Micron 8Gb DDR4 编码规则ConfigurationDDR4 寻址原理 Speed Grade内存的频率MT/s 与 MHz&#xff1a;更好的内存速度衡量指标为什么 DDR4 的核心频率与 I/O 总线频率的比例是 1:4 呢&#xff1f; 带宽 Altera FPGA…

CMU-15445(4)——PROJECT#1-BufferPoolManager-Task#2

PROJECT#1-BufferPoolManager Task #2 - Disk Scheduler 在前一节我实现了 TASK1 并通过了测试&#xff0c;在本节中&#xff0c;我将逐步实现 TASK2。 如上图&#xff0c;Page Table&#xff08;页表&#xff09;通过哈希表实现&#xff0c;用于跟踪当前存在于内存中的页&am…

百度智能云千帆携手联想,共创MCP生态宇宙

5月7日&#xff0c;2025联想创新科技大会&#xff08;Tech World&#xff09;在上海世博中心举行&#xff0c;本届大会以“让AI成为创新生产力”为主题。会上&#xff0c;联想集团董事长兼CEO杨元庆展示了包括覆盖全场景的超级智能体矩阵&#xff0c;包括个人超级智能体、企业超…

【动态导通电阻】GaN HEMT动态导通电阻的精确测量

2023 年 7 月,瑞士洛桑联邦理工学院的 Hongkeng Zhu 和 Elison Matioli 在《IEEE Transactions on Power Electronics》期刊发表了题为《Accurate Measurement of Dynamic ON-Resistance in GaN Transistors at Steady-State》的文章,基于提出的稳态测量方法,研究了氮化镓(…

java 使用zxing生成条形码(可自定义文字位置、边框样式)

最新工作中遇到生成条形码的需求&#xff0c;经过一番摸索之后找到了zxing这个工具类&#xff0c;实现效果如下&#xff1a; 首先引入依赖&#xff1a; <!-- 条形码生成器 --><dependency><groupId>com.google.zxing</groupId><artifactId&g…

day19-线性表(顺序表)(链表I)

一、补充 安装软件命令&#xff1a; sudo apt-get install (软件名) 安装格式化对齐&#xff1a;sudo apt-get install clang-format内存泄漏检测工具&#xff1a; sudo apt-get install valgrind 编译后&#xff0c;使用命令 valgrind ./a.out 即可看内存是…

CSS- 2.1 实战之图文混排、表格、表单、学校官网一级导航栏

本系列可作为前端学习系列的笔记&#xff0c;代码的运行环境是在HBuilder中&#xff0c;小编会将代码复制下来&#xff0c;大家复制下来就可以练习了&#xff0c;方便大家学习。 HTML系列文章 已经收录在前端专栏&#xff0c;有需要的宝宝们可以点击前端专栏查看&#xff01; 点…

从零搭建AI工作站:Gemma3大模型本地部署+WebUI配置全套方案

文章目录 前言1. 安装Ollama2.Gemma3模型安装与运行3. 安装Open WebUI图形化界面3.1 Open WebUI安装运行3.2 添加模型3.3 多模态测试 4. 安装内网穿透工具5. 配置固定公网地址总结 前言 如今各家的AI大模型厮杀得如火如荼&#xff0c;每天都有新的突破。今天我要给大家安利一款…

贝叶斯优化Transformer融合支持向量机多变量时间序列预测,Matlab实现

贝叶斯优化Transformer融合支持向量机多变量时间序列预测&#xff0c;Matlab实现 目录 贝叶斯优化Transformer融合支持向量机多变量时间序列预测&#xff0c;Matlab实现效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.BO-TransformerSVM多变量时间序列预测&#xff0c…

C++_STL_map与set

1. 关联式容器 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque、 forward_list(C11)等&#xff0c;这些容器统称为序列式容器&#xff0c;因为其底层为线性序列的数据结构&#xff0c;里面 存储的是元素本身。那什么是…

项目依赖版本修改

React项目 因UI库无法兼容React19版本,故此降低React版本至18.x (为什么不升级UI库版本,因为没有最新版,而且找不到好的替代品) package.json 先修改package.json文件中你想修改的依赖版本号 "dependencies": { - "react": "^19.1.0", - "…

蚁群算法赋能生鲜配送:MATLAB 实现多约束路径优化

在生鲜农产品配送中&#xff0c;如何平衡运输效率与成本控制始终是行业难题。本文聚焦多目标路径优化&#xff0c;通过 MATLAB 实现蚁群算法&#xff0c;解决包含载重限制、时间窗约束、冷藏货损成本的复杂配送问题。代码完整复现了从数据生成到路径优化的全流程&#xff0c;助…

机器学习与人工智能:NLP分词与文本相似度分析

自然语言处理 你有没有想过&#xff0c;生成式 AI 工具或大型语言模型背后究竟发生了什么&#xff1f;自然语言处理&#xff08;NLP&#xff09;是这些工具的核心&#xff0c;它使计算机能够理解人类语言。换句话说&#xff0c;NLP 是连接人类交流和机器&#xff08;如计算机&…

记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题

文章目录 前言一、问题记录二、参考帖子三、记录store.db.driverClassName 前言 记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题。 一、问题记录 17:39:23.709 ERROR --- [ionPool-Create-1134013833] com.alibaba.druid.pool.DruidDataSource : …

CUDA学习笔记

CUDA入门笔记 总览 CUDA是NVIDIA公司对其GPU产品提供的一个编程模型&#xff0c;在2006年提出&#xff0c;近年随着深度学习的广泛应用&#xff0c;CUDA已成为针对加速深度学习算法的并行计算工具。 以下是维基百科的定义&#xff1a;一种专有的并行计算平台和应用程序编程接…

c++ 类的语法3

测试下默认构造函数。demo1&#xff1a; void testClass3() {class Demo { // 没显示提供默认构造函数&#xff0c;会有默认构造函数。public:int x; // 普通成员变量&#xff0c;可默认构造};Demo demo1;//cout << "demo1.x: " << demo1.x << en…

Python 之类型注解

类型注解允许开发者显式地声明变量、函数参数和返回值的类型。但是加不加注解对于程序的运行没任何影响&#xff08;是非强制的&#xff0c;且类型注解不影响运行时行为&#xff09;&#xff0c;属于 有了挺好&#xff0c;没有也行。但是大型项目按照规范添加注解的话&#xff…

【linux】Web服务—搭建nginx+ssl的加密认证web服务器

准备工作 步骤&#xff1a; 一、 新建存储网站数据文件的目录 二、创建一个该目录下的默认页面&#xff0c;index.html 三、使用算法进行加密 四、制作证书 五、编辑配置文件&#xff0c;可以选择修改主配置文件&#xff0c;但是不建议 原因如下&#xff1a; 自定义一个配置文…

基于HTTP头部字段的SQL注入:SQLi-labs第17-20关

前置知识&#xff1a;HTTP头部介绍 HTTP&#xff08;超文本传输协议&#xff09;头部&#xff08;Headers&#xff09;是客户端和服务器在通信时传递的元数据&#xff0c;用于控制请求和响应的行为、传递附加信息或定义内容类型等。它们分为请求头&#xff08;Request Headers&…