⑩⑤【DB】详解MySQL存储过程:变量、游标、存储函数、循环,判断语句、参数传递..

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

在这里插入图片描述



1. 介绍

存储过程

  • 🚀什么是存储过程?
    • 存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的
    • 存储过程思想上很简单,就是数据库SQL语言层面的代码封装与重用。

  • 🚀存储过程的特点?
    • 代码的封装,复用
    • 可以接收参数,也可以返回数据
    • 减少网络交互,提升效率



2. 使用

存储过程的使用

  • 🚀创建存储过程:

    • -- DELIMITER关键字将SQL语句结束符号改为‘$$’,在创建存储过程后再改回‘;’
      -- 这是为了避免SQL语句的结束符号与END结束符号冲突,导致1064异常
      DELIMITER $$CREATE PROCEDURE 存储过程名称([参数列表])
      BEGIN-- SQL语句
      END$$DELIMITER ;
      

  • 🚀存储过程的调用:

    • CALL 存储过程名称([参数]);
      

  • 🚀查看存储过程的信息:

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

  • 🚀删除存储过程:

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



3. 变量

①系统变量

系统变量

  • 系统变量:是MySQL服务器提供,不是用户定义的,属于服务器层面。分为全局变量(GLOBAL)会话变量(SESSION)

  • 🚀查看系统变量:

    • #SESSION 或 GLOBAL 如果不指定,默认为SESSION
      -- 查看所有系统变量
      SHOW [SESSION | GLOBAL] VARIABLES;-- 通过LIKE模糊匹配方式查看系统变量
      SHOW [SESSION | GLOBAL] VARIABLES LIKE '....';-- 查看指定系统变量的值
      SELECT @@[SESSION | GLOBAL].系统变量名;
      
      • -- 演示-- 查看所有session级别系统变量
        SHOW VARIABLES;
        #或
        SHOW SESSION VARIABLES;-- 模糊匹配AUTO开头的系统变量
        SHOW SESSION VARIABLES LIKE 'AUTO%';
        SHOW GLOBAL VARIABLES LIKE 'AUTO%';-- 查看名为AUTOCOMMIT的系统变量
        SELECT @@GLOBAL.AUTOCOMMIT;
        SELECT @@SESSION.AUTOCOMMIT;
        

  • 🚀设置系统变量

    • #SESSION 或 GLOBAL 如果不指定,默认为SESSION
      SET [SESSION | GLOBAL] 系统变量名 = 自定义值;
      SET @@[SESSION | GLOBAL].系统变量名 = 自定义值;
      

注意

  • 设置或查看系统变量时,SESSION 或 GLOBAL 如果不指定,**默认为SESSION **。
  • MySQL服务重新启动后,所设置的全局变量都会重置,想要不失效,可以在配置文件/etc/my.cnf文件中配置。



② 用户定义变量

用户定义变量

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

  • 🚀用户定义变量的赋值**(4种方式)** :

    • -- var_name:用户定义变量名,由用户自定义
      -- expr:用户定义变量的值,由用户自定义
      #方式一:
      SET @var_name = expr [,@var_name = expr]...;
      #方式二:
      SET @var_name := expr [,@var_name := expr]...;
      #方式三:
      SELECT @var_name := expr [,@var_name := expr]...;
      #方式四(将查询结果赋值给变量):
      SELECT 字段名 INTO @var_name FROM 表名;
      

  • 🚀用户定义变量的使用:

    • -- var_name:用户定义变量名,由用户自定义
      SELECT @var_name [,@var_name...];
      

注意:用户定义的变量无需对其进行声明或初始化,不声明或初始化获取到的值为NULL。



③ 局部变量

局部变量

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

  • 🚀声明局部变量:

    • DECLARE 变量名 变量类型 [DEFAULT...];
      
    • 变量类型:就是数据库字段类型:INT,BIGINT,CHAR,VARCHAR,DATE,TIME等。


  • 🚀为局部变量赋值:

    • SET 变量名 =;
      SET 变量名 :=;
      SELECT 字段名 INTO 变量名 FROM 表名 WHERE 查询条件...;
      



4. 条件判断语句IF

  • 🚀 语法

    • IF 条件1 THEN-- 执行逻辑
      ELSEIF 条件2 THEN   -- 可选-- 执行逻辑
      ELSE               -- 可选-- 执行逻辑
      END IF;	
      
      • -- 演示
        /*
        给成绩打分
        分数score >= 80 结果result就是优秀
        分数80 > score >= 60 结果result就是优秀
        分数score < 60 结果result就是不及格
        */
        DELIMITER $$CREATE PROCEDURE p3()
        BEGINDECLARE score INT DEFAULT 58;DECLARE result VARCHAR(10);IF score >= 80 THENSET result = '优秀';ELSEIF score >= 60 THENSET result = '合格';ELSESET result = '不合格';END IF;SELECT result;
        END$$DELIMITER ;
        



5. 参数传递

参数

在这里插入图片描述


  • 🚀参数传递的用法:

    • DELIMITER $$CREATE PROCEDURE 存储过程名称([IN | OUT | INOUT 参数名 参数类型])
      BEGIN-- SQL语句
      END$$DELIMITER ;
      
      • -- 演示
        /*
        1. 根据传入(in)参数score,判定当前分数对应的分数等级,并返回(out)
        分数score >= 80 结果result就是优秀
        分数80 > score >= 60 结果result就是优秀
        分数score < 60 结果result就是不及格
        */
        DELIMITER $$CREATE PROCEDURE p4(IN score INT,OUT result VARCHAR(10))
        BEGINIF score >= 80 THENSET result = '优秀';ELSEIF score >= 60 THENSET result = '合格';ELSESET result = '不合格';END IF;
        END$$DELIMITER ;-- 调用存储过程,查看返回结果。
        CALL p4(100,@result);
        SELECT @result;-- 2. 传入两百分制数,转换为一百分制数输出(inout)
        DELIMITER $$CREATE PROCEDURE p5(INOUT score DOUBLE)
        BEGINSET score = score * 0.5;
        END$$DELIMITER ;-- 设置自定参数传入,获取转换后的参数。
        SET @score = 180;
        CALL p5(@score);
        SELECT @score;
        



6. CASE语句

  • 🚀CASE语法一:

  • 如果when_value = case_value,就会执行对应THEN后面的statement_list逻辑

    • -- 存储过程中使用CASE
      DELIMITER $$CREATE PROCEDURE 存储过程名称([IN | OUT | INOUT 参数名 参数类型])
      BEGINCASE case_valueWHEN when_value1 THEN statement_list1[WHEN when_value2 THEN statement_list2][ELSE statement_list]END CASE;
      END$$DELIMITER ;
      

  • 🚀CASE语法二:

  • 如果search_condition的结果为TRUE,就会执行对应THEN后面的statement_list逻辑

    • -- 存储过程中使用CASE
      DELIMITER $$CREATE PROCEDURE 存储过程名称([IN | OUT | INOUT 参数名 参数类型])
      BEGINCASEWHEN search_condition1 THEN statement_list1[WHEN search_condition2 THEN statement_list2][ELSE statement_list]END CASE;
      END$$DELIMITER ;



7. 循环语句

①while循环

while

  • while循环是有条件的循环控制语句。满足条件后,再执行循环体中的SQL语句。具体语法为:

    • -- 先判定条件,条件结果为TRUE则执行逻辑,否则不执行语句。
      WHILE 条件 DO#SQL逻辑
      END WHILE;
      
    • -- 存储过程中使用WHILE
      DELIMITER $$CREATE PROCEDURE 存储过程名称([IN | OUT | INOUT 参数名 参数类型])
      BEGINWHILE 条件 DO#SQL逻辑END WHILE;
      END$$DELIMITER ;
      



②repeat循环

repeat:

  • repeat是有条件的循环控制语句,当满足条件的时候退出循环 。具体语法为:

    • -- 先执行一次逻辑,然后判定逻辑是否为True,如果True则退出循环,不满足判定则继续循环。
      REPEAT#SQL逻辑UNTIL 条件
      END REPEAT;
      
    • -- 存储过程中使用REPEAT
      DELIMITER $$CREATE PROCEDURE 存储过程名称([IN | OUT | INOUT 参数名 参数类型])
      BEGINREPEAT#SQL逻辑UNTIL 条件END REPEAT;
      END$$DELIMITER ;
      



③loop循环

loop

  • LOOP实现简单的循环,如果不在SQL逻辑中增加退出循环的条件,可以用其来实现简单的死循环。LOOP可以配合一下两个语句使用
    • LEVEL:配合循环使用,退出循环。
    • ITERATE:必须用在循环中,作用是跳过当前循环剩下的语句,直接进入下一次循环。

  • 🚀loop循环语法:

    • -- begin_label: 是标记
      -- end_label 是结束标记
      [begin_label:] LOOP#SQL逻辑
      END LOOP [end_label];
      
    • -- 退出指定label标记的循环体
      LEVEL label;-- 跳过本次循环,直接进入下一次循环
      ITERATE label;
      



8. 游标 和 条件处理程序

①游标 cursor

cursor

  • 游标(CURSOR)
  • 是用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理。游标的使用包括游标的声明OPENFETCHCLOSE

  • 🚀游标的声明:

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

  • 🚀打开游标:

    • OPEN 游标名称;
      

  • 🚀获取游标记录:

    • FETCH 游标名称 INTO 变量1[,变量2,...];
      

  • 🚀关闭游标:

    • CLOSE 游标名称;
      



②条件处理程序 Handler

Handler

  • 条件处理程序(Handler)

  • 可以用来定义在流程控制结构执行过程中遇到问题时相应的处理步骤 。具体语法为:

    • -- 语法
      DECLARE handler_action HANDLER FOR
      condition_value [,condition_value,...] 
      statement;-- handler_action的解释:
      CONTINUE #继续执行当前程序
      EXIT     #终止执行当前程序-- condition_value的解释:
      SQLSTATE 'lstate_value' #状态码,如02000
      SQLWARNING		#所有01开头的SQLSTATE代码的简写
      NOT FOUND		#所有02开头的SQLSTATE代码的简写
      SQLEXCEPTION	#所有没有被SQLWARNING或NOT FOUND捕获的代码的简写-- statement解释
      /*
      程序满足condition_value就会执行handler_action,
      执行完handler_action操作后就会执行statement的操作
      */


③使用案例

  • 演示

    • – 要求:
      /*
      根据传入的参数uage,来查询用户表tb_user中,
      所有的用户年龄小于等于uage的用户姓名(name)和专业(profession),
      并将用户的姓名和专业插入到所创建的一张新表(id,name,profession)中。
      */

      – 逻辑:
      – 1.声明游标,存储查询结果集
      – 2.准备:创建表结构
      – 3.开启游标
      – 4.获取游标中的记录
      – 5.插入数据到新表
      – 6.关闭游标

    • #修改结束标志,避免代码无法正常执行完毕
      DELIMITER $$CREATE PROCEDURE p11(IN uage INT)
      BEGIN#声明第4步使用的变量DECLARE uname VARCHAR(50);DECLARE uprofession VARCHAR(11);#1.声明游标,存储查询结果集DECLARE u_cursor CURSOR FOR SELECT NAME,profession FROM tb_user WHERE age <= uage;#声明条件处理程序Handler,#满足NOT FOUND就执行exit操作#执行完后,关闭游标:CLOSE u_cursor。-- 这个handler的目的是:若游标内没有数据,直接退出并关闭游标DECLARE EXIT HANDLER FOR NOT FOUND CLOSE u_cursor;#2.准备:创建表结构DROP TABLE IF EXISTS tb_user_pro;CREATE TABLE IF NOT EXISTS tb_user_pro(id INT PRIMARY KEY AUTO_INCREMENT,NAME VARCHAR(50) NOT NULL,profession VARCHAR(11));#3.开启游标OPEN u_cursor;#4.获取游标中的记录(循环)WHILE TRUE DO#获取游标数据存入变量FETCH u_cursor INTO uname,uprofession;#5.插入数据到新表INSERT INTO tb_user_pro VALUES(NULL,uname,uprofession);END WHILE;#6.关闭游标CLOSE u_cursor;
      END$$#恢复原本的结束标志
      DELIMITER ; -- 调用存储过程
      CALL P11(60);
      -- 查看是新表否达到要求
      SELECT * FROM tb_user_pro;
      



9. 存储函数

存储函数

  • 存储函数是有返回值的存储过程,存储函数的参数只能是IN类型。

  • 🚀存储函数的使用:

    • -- 语法:
      DELIMITER $$CREATE FUNCTION 存储函数名称([参数列表])
      RETURNS type [characteristic...]
      BEGIN-- SQL语句RETURN...;
      END $$DELIMITER ;#######################################-- characteristic的解释:
      DETERMINISTIC  #相同的输入参数总是产生相同的结果
      NO SQL         #不包含SQL语句
      READS SQL DATA #包含读取数据的语句,但不包含写入数据的语句。
      

  • 演示

    • 使用存储函数,实现从1到n的累加

    • -- 使用存储函数,实现从1到n的累加
      DELIMITER $$CREATE FUNCTION f(n INT)
      RETURNS INT DETERMINISTIC
      BEGIN-- SQL语句DECLARE total INT DEFAULT 0;WHILE n > 0 DOSET total = total + n;SET n = n - 1;END WHILE;-- 返回RETURN total;
      END $$DELIMITER ;-- 验证结果
      SELECT f(100);
      




在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每天学习一点点之 Spring Web MVC 之抽象 HandlerInterceptor 实现常用功能(限流、权限等)

背景 这里介绍一下本文的背景&#xff08;废话&#xff0c;可跳过&#xff09;。上周有个我们服务的调用方反馈某个接口调用失败率很高&#xff0c;排查了一下&#xff0c;发现是因为这个接口被我之前写的一个限流器给拦截了&#xff0c;随着我们的服务接入了 Sentinel&#x…

MTK Pump Express 快速充电原理分析

1 MTK PE 1.1 原理 在讲正文之前&#xff0c;我们先看一个例子。 对于一块电池&#xff0c;我们假设它的容量是6000mAh&#xff0c;并且标称电压是3.7V&#xff0c;换算成Wh(瓦时)为单位的值是22.3Wh(6000mAh*3.7V)&#xff1b;普通的充电器输出电压电流是5V2A(10W)&#xff0c…

RK3588平台开发系列讲解(项目篇)嵌入式AI的学习步骤

文章目录 一、嵌入式AI的学习步骤1.1、入门Linux1.2、入门AI 二、瑞芯微嵌入式AI2.1、瑞芯微的嵌入式AI关键词2.2、AI模型部署流程 沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;&#x1f604; &#x1f4e2; 本篇将给大家介绍什么是嵌入式AI。 一、嵌入…

Docker与Kubernetes结合的难题与技术解决方案

文章目录 1. **版本兼容性**技术解决方案 2. **网络通信**技术解决方案 3. **存储卷的管理**技术解决方案 4. **安全性**技术解决方案 5. **监控和日志**技术解决方案 6. **扩展性与自动化**技术解决方案 7. **多集群管理**技术解决方案 结语 &#x1f388;个人主页&#xff1a…

编程刷题网站以及实用型网站推荐

1、牛客网在线编程 牛客网在线编程https://www.nowcoder.com/exam/oj?page1&tab%E8%AF%AD%E6%B3%95%E7%AF%87&topicId220 2、力扣 力扣https://leetcode.cn/problemset/all/ 3、练码 练码https://www.lintcode.com/ 4、PTA | 程序设计类实验辅助教学平台 PTA | 程…

【Java 进阶篇】Ajax 实现——原生JS方式

大家好&#xff0c;欢迎来到这篇关于原生 JavaScript 中使用 Ajax 实现的博客&#xff01;在前端开发中&#xff0c;我们经常需要与服务器进行数据交互&#xff0c;而 Ajax&#xff08;Asynchronous JavaScript and XML&#xff09;是一种用于创建异步请求的技术&#xff0c;它…

云原生专栏丨基于服务网格的企业级灰度发布技术

灰度发布&#xff08;又名金丝雀发布&#xff09;是指在黑与白之间&#xff0c;能够平滑过渡的一种发布方式。在其上可以进行A/B testing&#xff0c;即让一部分用户继续用产品特性A&#xff0c;一部分用户开始用产品特性B&#xff0c;如果用户对B没有什么反对意见&#xff0c;…

广州华锐互动VRAR:VR教学楼地震模拟体验增强学生防震减灾意识

在当今社会&#xff0c;地震作为一种自然灾害&#xff0c;给人们的生活带来了巨大的威胁。特别是在学校这样的集体场所&#xff0c;一旦发生地震&#xff0c;后果将不堪设想。因此&#xff0c;加强校园安全教育&#xff0c;提高师生的防震减灾意识和能力&#xff0c;已经成为了…

springboot中动态api如何设置

1.不需要编写controller 等mvc层&#xff0c;通过接口动态生成api。 这个问题&#xff0c;其实很好解决&#xff0c;以前编写接口&#xff0c;是要写controller&#xff0c;需要有 RestController RequestMapping("/test1") public class xxxController{ ApiOperat…

Zotero在word中插入带超链接的参考文献/交叉引用/跳转参考文献

Zotero以其丰富的插件而闻名&#xff0c;使用起来十分的带劲&#xff0c;最重要的是它是免费的、不卡顿&#xff0c;不像某专业软件。 然而Zotero在word插入参考文献时&#xff0c;无法为参考文献添加超链接&#xff0c;这是一个不得不提的遗憾。 不过&#xff0c;有大佬已经…

asp.net健身会所管理系统sqlserver

asp.net健身会所管理系统sqlserver说明文档 运行前附加数据库.mdf&#xff08;或sql生成数据库&#xff09; 主要技术&#xff1a; 基于asp.net架构和sql server数据库 功能模块&#xff1a; 首页 会员注册 教练预约 系统公告 健身课程 在线办卡 用户中心[修改个人信息 修…

设计模式-行为型模式-模板方法模式

一、什么是模板模式 模板方法模式&#xff08;Template Method Pattern&#xff09;是一种行为型设计模式&#xff0c;它定义了一个算法骨架&#xff0c;允许子类在不改变算法整体结构的情况下重新定义算法的某些步骤。 主要组成部分&#xff1a; 1、模板方法&#xff08;Templ…

如何在面试中胜出?接口自动化面试题安排上

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

AIGC 技术在淘淘秀场景的探索与实践

本文介绍了AIGC相关领域的爆发式增长&#xff0c;并探讨了淘宝秀秀(AI买家秀)的设计思路和技术方案。文章涵盖了图像生成、仿真形象生成和换背景方案&#xff0c;以及模型流程串联等关键技术。 文章还介绍了淘淘秀的使用流程和遇到的问题及处理方法。最后&#xff0c;文章展望…

从一到无穷大 #19 TagTree,倒排索引入手是否是优化时序数据库查询的通用方案?

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。 本作品 (李兆龙 博文, 由 李兆龙 创作)&#xff0c;由 李兆龙 确认&#xff0c;转载请注明版权。 文章目录 文章主旨时序数据库查询的一般流程扫描维度聚合时间聚合管控语句 TagTree整体结构索引…

ArkTS - HarmonyOS服务卡片(创建)

可以参考官网文档 其中我们在已有的文件中File > New > Service Widget创建你想要的小卡片 本文章发布时目前可使用的模板就三种 有卡片后的new 最终效果

「Verilog学习笔记」实现3-8译码器①

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 分析 ① 本题要求根据38译码器的功能表实现该电路&#xff0c;同时要求采用基础逻辑门实现&#xff0c;那么就需要将功能表转换为逻辑表达式。 timescale 1ns/1nsmodule d…

K8S基础笔记

1、namespace 名称空间用来对集群资源进行隔离划分&#xff0c;默认只隔离资源&#xff0c;不隔离网络k8s默认的名称空间为default 查看k8s的所有命名空间 kubectl get namespace 或者 kubectl get ns 创建名称空间 kubectl create ns 名称 或使用yaml方式 编写yamlkub…

竞赛 题目:基于大数据的用户画像分析系统 数据分析 开题

文章目录 1 前言2 用户画像分析概述2.1 用户画像构建的相关技术2.2 标签体系2.3 标签优先级 3 实站 - 百货商场用户画像描述与价值分析3.1 数据格式3.2 数据预处理3.3 会员年龄构成3.4 订单占比 消费画像3.5 季度偏好画像3.6 会员用户画像与特征3.6.1 构建会员用户业务特征标签…

应试教育导致学生迷信标准答案惯性导致思维僵化-移动机器人

移动机器人课程群实践创新的困境与突围 一、引言 随着科技的快速发展&#xff0c;工程教育变得越来越重要。然而&#xff0c;传统的应试教育模式往往侧重于理论知识的传授&#xff0c;忽视了学生的实践能力和创新精神的培养。这在移动机器人课程群的教学中表现得尤为明显。本文…