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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 【MySQL】探索MySQL存储过程的魔力,初学者的数据库编程秘笈(内含实战SQL脚本)

🌟前言


MySQL存储过程作为一种服务器端的数据库编程方式,提供了高效、可重用的方法来执行相对复杂的数据库操作。本篇文章主要针对初学者,展开对MySQL存储过程的讲解,帮助MySQL初学者能够更好的学习。


🌟存储过程介绍


定义:


存储过程是一组预定义的SQL语句集合,被存储在数据库中,以便复用和调用。它们可以接收参数、执行逻辑判断、进行循环和异常处理,并返回结果。存储过程在数据库服务器上执行,减少了网络传输的开销,提升了性能。

MySQL存储过程支持常见的编程结构,如条件语句(IF-ELSE、CASE)、循环(WHILE、LOOP)和异常处理(TRY-CATCH)。除了基本的SQL语句,还可以通过使用变量、游标和临时表等特性,实现更复杂的操作和逻辑。


优势:


提高性能:存储过程在数据库服务器上执行,减少了与客户端的数据传输,降低了网络开销,从而提高了性能。此外,存储过程可以被编译和优化,减少了重复代码的冗余,进一步提升了查询执行效率。

简化复杂的查询:对于复杂的查询或需要按特定顺序执行的多个查询,存储过程提供了一种简洁、可重用的解决方案。通过将逻辑封装在存储过程中,可以减少应用程序中的SQL代码量,使数据库逻辑更清晰、易于维护。

增强安全性:存储过程可以设置为只能由特定用户或角色调用,从而增强了对数据库的安全性。

减轻客户端负担:将复杂的业务逻辑放在存储过程中,可以减轻客户端的负担。客户端只需调用相应的存储过程,而无需编写冗长的SQL语句和处理复杂的结果集,简化了应用程序的开发和维护。


劣势:


可移植性较差:存储过程在不同的数据库系统之间的语法和特性可能存在差异,这导致了存储过程的可移植性较差。如果需要将应用程序迁移到另一个数据库系统,可能需要对存储过程进行调整和修改。

难以调试和维护:存储过程的调试和维护相对复杂。由于存储过程在数据库服务器上执行,无法像客户端应用程序那样方便地进行调试。此外,存储过程的逻辑可能分散在多个存储过程中,增加了维护的难度。


🌟存储过程基本语法


创建:相当于Java中定义方法


CREATE [DEFINER = {user | CURRENT_USER}] PROCEDURE procedure_name ([parameter_list])
    [characteristic ...]
    BEGIN
        DECLARE variable_name data_type; -- 声明变量
        -- 存储过程的逻辑代码
    END;


DEFINER:可选项,创建存储过程的用户。可以指定具体的用户名,或使用CURRENT_USER表示当前用户。

procedure_name:指定存储过程的名称,遵循标识符命名规则。

parameter_list:可选项,用于指定存储过程的参数列表。参数由参数类型和参数名称组成,多个参数之间使用逗号分隔。参数类型可以是IN、OUT 或 INOUT,分别表示输入参数、输出参数和既是输入参数又是输出参数(赋值)。

characteristic:可选项,用于指定存储过程的特性。常用特性包括:


  • LANGUAGE SQL:表示存储过程使用 SQL 语言编写。
  • [NOT] DETERMINISTIC:指示存储过程是否是确定性的,即相同输入是否总是产生相同的结果。
  • CONTAINS SQL:表示存储过程包含 SQL 语句。
  • NO SQL:表示存储过程不包含 SQL 语句。
  • READS SQL DATA:表示存储过程只读取数据,不修改数据。
  • MODIFIES SQL DATA:表示存储过程修改数据。


BEGIN和END:定义存储过程的逻辑代码块的开始和结束位置。

DECLARE:用于声明变量。在存储过程的逻辑代码块中,可以使用DECLARE语句来声明变量,指定变量名称和数据类型。


调用:相当于Java中调用方法

CALL procedure_name([argument_list]);


CALL:关键字用于调用存储过程。

procedure_name:要调用的存储过程的名称。

argument_list:可选项,用于传递给存储过程的参数列表。参数与存储过程定义时指定的参数列表对应,多个参数之间使用逗号分隔。如果存储过程没有参数,可以省略该部分。


🌟存储过程实战


以下例子,均按下表进行操作


7d0ba1e9f0c4de78aec3e5e6d13e3058_7b07f05ba88942e0993b6cc0243b99cd.png


SQL语句:


--创建表
CREATE TABLE employees (
    id INT PRIMARY KEY,
    name VARCHAR(255),
    age INT,
    salary DECIMAL(10, 2)
);
--表中插入数据
INSERT INTO employees (id, name, age, salary)
VALUES
    (1, '张三', 25, 5000),
    (2, '李四', 30, 6000),
    (3, '王五', 35, 7000),
    (4, '赵六', 40, 8000),
    (5, '钱七', 45, 9000);


无参数列表存储过程


此存储过程名为getAllEmployees。它将从employees表中检索所有的员工记录并返回结果集。


CREATE PROCEDURE getAllEmployees()
BEGIN
    SELECT * FROM employees;
END;


调用存储过程进行检验

CALL getAllEmployees();


检验结果:


e5b11c47c89b09cbbca859c9deb0fde0_08b17ca4bc204a95803ff527c96376b3.png


带参数列表存储过程


此存储过程名为getEmployeeById,它接受一个输入参数empId,通过这个参数来查询与给定id相匹配的员工记录。


CREATE PROCEDURE getEmployeeById(IN empId INT)
BEGIN
    SELECT * FROM employees WHERE id = empId;
END;


调用存储过程进行检验

CALL getEmployeeById(2);


检验结果


f953f613c37935bb343fad071329d91c_5aae5155cb8f47e794d2ee4e5d4a4c53.png


带流程控制语句IF ELSE存储过程


此存储过程名为getEmployeeSalaryGrade,它接受一个输入参数empId,根据员工的薪水确定员工的薪资等级。根据不同的薪水范围,将员工的薪资等级分为"低级"、“中级"和"高级”。


CREATE PROCEDURE getEmployeeSalaryGrade(IN empId INT)
BEGIN
    DECLARE empSalary DECIMAL(10, 2);
    DECLARE empGrade VARCHAR(10);
    SELECT salary INTO empSalary FROM employees WHERE id = empId;
    IF empSalary < 5000 THEN
        SET empGrade = '低级';
    ELSEIF empSalary >= 5000 AND empSalary < 8000 THEN
        SET empGrade = '中级';
    ELSE
        SET empGrade = '高级';
    END IF;
    SELECT empGrade AS grade;
END;


调用存储过程进行检验

call getEmployeeSalaryGrade(3)


检验结果


53895831b761f982758be5d7f7c0b7a1_31fa6efffe0b4fd284ccd7c3377d0c0a.png


带条件控制语句CASE存储过程


此存储过程名为categorizeEmployee,它根据员工的姓名确定员工的职位。


CREATE PROCEDURE categorizeEmployee()
BEGIN
    SELECT id, name,
        CASE
            WHEN name = '张三' THEN '管理人员'
            WHEN name = '李四' THEN '管理人员'
            ELSE '普通员工'
        END AS category
    FROM employees;
END;


调用存储过程进行检验

call categorizeEmployee()


检验结果


62da806085a22e253142dd0241480b00_34b7aa622f7f4a4c9503bef802937ba1.png


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
5月前
|
SQL Oracle 关系型数据库
MySQL的sql_mode模式说明及设置
MySQL的sql_mode模式说明及设置
760 112
|
4月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
881 152
|
6月前
|
存储 SQL 关系型数据库
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
|
4月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
4月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
4月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
4月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
484 11
|
7月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
552 62
|
4月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。

推荐镜像

更多