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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【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 存储过程名;


🌟写在最后


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


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
|
2月前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
165 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
2月前
|
SQL 数据库 UED
SQL性能提升秘籍:5步优化法与10个实战案例
在数据库管理和应用开发中,SQL查询的性能优化至关重要。高效的SQL查询不仅可以提高应用的响应速度,还能降低服务器负载,提升用户体验。本文将分享SQL优化的五大步骤和十个实战案例,帮助构建高效、稳定的数据库应用。
76 3
|
2月前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
56 4
|
3月前
|
SQL NoSQL 数据库
Cassandra数据库与Cql实战笔记
Cassandra数据库与Cql实战笔记
44 1
Cassandra数据库与Cql实战笔记
|
2月前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
343 1
|
2月前
|
存储 SQL NoSQL
|
2月前
|
SQL 缓存 监控
SQL性能提升指南:五大优化策略与十个实战案例
在数据库性能优化的世界里,SQL优化是提升查询效率的关键。一个高效的SQL查询可以显著减少数据库的负载,提高应用响应速度,甚至影响整个系统的稳定性和扩展性。本文将介绍SQL优化的五大步骤,并结合十个实战案例,为你提供一份详尽的性能提升指南。
57 0
|
3月前
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
148 1
|
3月前
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
171 1