【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)下

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)

带循环语句WHILE存储过程


此存储过程名为 IncreaseSalary,它会遍历 employees 表中的每个员工,并将他们的薪水增加 10%。


CREATE PROCEDURE IncreaseSalary()
BEGIN
    DECLARE emp_count INT;
    DECLARE i INT DEFAULT 0;
    DECLARE emp_id INT;
    DECLARE emp_salary DECIMAL(10, 2);
    -- 获取员工数量
    SELECT COUNT(*) INTO emp_count FROM employees;
    -- 循环遍历并更新薪水
    WHILE i < emp_count DO
        SET i = i + 1;
        -- 获取当前员工的id和薪水
        SELECT id, salary INTO emp_id, emp_salary FROM employees WHERE id = i;
        -- 对薪水进行增加
        UPDATE employees SET salary = emp_salary * 1.1 WHERE id = emp_id;
    END WHILE;
END;


调用存储过程进行检验

CALL IncreaseSalary();


检验结果

原来薪水


6e4f475b27e1cc0c7ea6c762413edec5_a7ab0e4ef4ff4f9b975f612f34e30ebf.png


当前薪水


e8f17b42e73946014c3e245bc4464e10_10ac5bb250b442968042fb929a8ab052.png


带循环语句REPEAT UNTIL存储过程


此存储过程名为 DisplayEmployeesWithRepeatUntil,它会使用 REPEAT…UNTIL 循环遍历 employees 表中的每个员工,并输出他们的信息。


DELIMITER $$
CREATE PROCEDURE DisplayEmployeesWithRepeatUntil()
BEGIN
--声明变量
    DECLARE emp_count INT;--员工数量
    DECLARE i INT DEFAULT 1;
    DECLARE emp_id INT;
    DECLARE emp_name VARCHAR(50);
    DECLARE emp_age INT;
    DECLARE emp_salary DECIMAL(10, 2);
    -- 获取员工数量
    SELECT COUNT(*) INTO emp_count FROM employees;
    -- 循环遍历并输出员工信息
    REPEAT
        -- 获取当前员工信息
        SELECT id, name, age, salary INTO emp_id, emp_name, emp_age, emp_salary FROM employees WHERE id = i;
        -- 输出员工信息
        SELECT CONCAT('ID: ', emp_id, ', Name: ', emp_name, ', Age: ', emp_age, ', Salary: ', emp_salary) AS employee_info;
        SET i = i + 1;
    UNTIL i > emp_count END REPEAT;
END$$
DELIMITER ;


调用存储过程进行检验

CALL DisplayEmployeesWithRepeatUntil();


检验结果


0fe2f610d018c98a1409628663887acd_4cc3e680a3c5479789e5a7c466f6fb0e.png


带循环语句LOOP存储过程


此存储过程名为 DisplayEmployeesWithLoop,它会使用LOOP循环遍历 employees 表中的每个员工,并输出他们的信息。


CREATE PROCEDURE DisplayEmployeesWithLoop()
BEGIN
    DECLARE emp_count INT;
    DECLARE i INT DEFAULT 1;
    DECLARE emp_id INT;
    DECLARE emp_name VARCHAR(50);
    DECLARE emp_age INT;
    DECLARE emp_salary DECIMAL(10, 2);
    -- 获取员工数量
    SELECT COUNT(*) INTO emp_count FROM employees;
    -- 循环遍历并输出员工信息
    emp_loop: LOOP
        -- 获取当前员工信息
        SELECT id, name, age, salary INTO emp_id, emp_name, emp_age, emp_salary FROM employees WHERE id = i;
        -- 输出员工信息
        SELECT CONCAT('ID: ', emp_id, ', Name: ', emp_name, ', Age: ', emp_age, ', Salary: ', emp_salary) AS employee_info;
        SET i = i + 1;
        IF i > emp_count THEN
            LEAVE emp_loop;
        END IF;
    END LOOP;
END;


调用存储过程检验

CALL DisplayEmployeesWithLoop();


检验结果

85ccfeb2584421b42af438ddd035c353_03a3f2c658444cc5bc91bcff23b053d0.png


查询存储过程


--查询所有数据库
SHOW PROCEDURE STATUS;
--查询指定数据库test。以上所有例子都基于test数据库
SHOW PROCEDURE STATUS WHERE db='test'


结果


cb41d29269536ea484a09b92e924469d_625e6a0751e349a7971ea0e60df7ebec.png


查询存储过程定义源码


SHOW CREATE PROCEDURE 存储过程名;
SHOW CREATE PROCEDURE categorizeEmployee;


结果


a51fcb3fa050764b1826cff772e94cf7_7bb31b1dff1146a997d4e6bd2ed7f4b0.png


删除存储过程


DROP PROCEDURE 存储过程名;


🌟写在最后


最后感谢大家对于此博文的阅读,如对存储过程有补充或者疑问之处,请大家在评论区留言。感谢大家的指正与点评。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
存储 关系型数据库 MySQL
MySQL数据库实战:从入门到精通
本文介绍了MySQL的使用和优化,适合Web开发者阅读。首先,确保安装并配置好MySQL,熟悉SQL基础。接着,通过命令行客户端连接数据库,执行创建、查询、添加、修改和删除数据等操作。学习数据类型并创建表存储数据。最后,探讨了数据库优化,包括查询优化和索引使用,以提升性能。
10 2
|
4天前
|
安全 关系型数据库 MySQL
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
14 3
|
5天前
|
SQL 关系型数据库 MySQL
不允许你不知道的 MySQL 优化实战(一)
不允许你不知道的 MySQL 优化实战(一)
11 2
|
6天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
|
8天前
|
关系型数据库 MySQL 中间件
【MySQL实战笔记】07 | 行锁功过:怎么减少行锁对性能的影响?-02 死锁和死锁检测
【4月更文挑战第19天】在高并发环境下,死锁发生在多个线程间循环等待资源时,导致无限期等待。MySQL中,死锁可通过`innodb_lock_wait_timeout`参数设置超时或`innodb_deadlock_detect`开启死锁检测来解决。默认的50s超时可能不适用于在线服务,而频繁检测会消耗大量CPU。应对热点行更新引发的性能问题,可以暂时关闭死锁检测(风险是产生大量超时),控制并发度,或通过分散记录减少锁冲突,例如将数据分拆到多行以降低死锁概率。
22 1
|
11天前
|
SQL 关系型数据库 MySQL
Python与MySQL数据库交互:面试实战
【4月更文挑战第16天】本文介绍了Python与MySQL交互的面试重点,包括使用`mysql-connector-python`或`pymysql`连接数据库、执行SQL查询、异常处理、防止SQL注入、事务管理和ORM框架。易错点包括忘记关闭连接、忽视异常处理、硬编码SQL、忽略事务及过度依赖低效查询。通过理解这些问题和提供策略,可提升面试表现。
30 6
|
11天前
|
SQL 自然语言处理 数据库
NL2SQL实践系列(2):2024最新模型实战效果(Chat2DB-GLM、书生·浦语2、InternLM2-SQL等)以及工业级案例教学
NL2SQL实践系列(2):2024最新模型实战效果(Chat2DB-GLM、书生·浦语2、InternLM2-SQL等)以及工业级案例教学
NL2SQL实践系列(2):2024最新模型实战效果(Chat2DB-GLM、书生·浦语2、InternLM2-SQL等)以及工业级案例教学
|
15天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
18天前
|
存储 关系型数据库 MySQL
【MySQL实战笔记】 04 | 深入浅出索引(上)-02
【4月更文挑战第9天】InnoDB数据库使用B+树作为索引模型,其中主键索引的叶子节点存储完整行数据,非主键索引则存储主键值。主键查询只需搜索一棵树,而非主键查询需两次搜索,因此推荐使用主键查询以提高效率。在插入新值时,B+树需要维护有序性,可能导致数据页分裂影响性能。自增主键在插入时可避免数据挪动和页分裂,且占用存储空间小,通常更为理想。然而,如果场景仅需唯一索引,可直接设为主键以减少查询步骤。
17 1
【MySQL实战笔记】 04 | 深入浅出索引(上)-02
|
27天前
|
存储 SQL 关系型数据库
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)