学习MySQL的第十二天

夕阳西下

云霞满天

一、存储过程概述

1.1 理解

含义:存储过程的英文是 Stored Procedure。它的思想很简单,就是一组经过预先编译的SQL语句的封装。

执行过程:存储过程预先存储在MySQL服务器上,需要执行的时候,客户端只需要向服务器端发出调用存储过程的命令,服务器端就可以把预先存储好的这一系列SQL语句全部执行。

好处:

1、简化操作,提高了sql语句的重用性,减少了开发程序员的压力

2、减少操作过程中的失误,提高效率

3、减少网络传输量(客户端不需要把所有的SQL语句通过网络发给服务器)

4、减少了SQL语句暴露在网上的风险,也提高了数据查询的安全性

分类:

存储过程的参数类型可以是IN、OUT和INOUT。根据这点分类如下:

1、没有参数(无参数无返回)

2、仅仅带IN类型(有参数无返回)

3、仅仅带OUT类型(无参数有返回)

4、既带IN又带OUT(有参数有返回)

5、带INOUT(有参数有返回)

注意:IN、OUT、INOUT都可以在一个存储过程中带多个。

1.2 创建存储过程

*CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 函数类型,...)

characteristics ...

BEGIN
存储过程体
END;*

(1)创建存储过程 SELECT_all_data(),查看 company 表中的所有数据
sql 复制代码
CREATE PROCEDURE cunchu()
BEGIN
  SELECT * FROM company;
END;
(2)存储过程的调用
sql 复制代码
CALL cunchu()
(3)示例:查询最高工资
sql 复制代码
CREATE PROCEDURE MaxSalary()
BEGIN
  SELECT e.salary,e.employee_name
  FROM employee e
  WHERE e.salary = (
    SELECT MAX(salary)
    FROM employee
  );  /*每个命令结束后都要加上`;`*/
END;

CALL MaxSalary();
(4)用in 参数输入员工姓名
sql 复制代码
CREATE PROCEDURE ININ(IN name VARCHAR(20))
BEGIN
  SELECT * FROM employee
  WHERE employee.employee_name = name;
END;

CALL inin('王强');
(5)带 in 和 out

用 IN 输入员工姓名,用out输出员工薪资

sql 复制代码
CREATE PROCEDURE GetSalaryByName(IN name VARCHAR(20),OUT salary decimal(10,2))
BEGIN
  SELECT employee.salary INTO salary
  FROM employee
  WHERE employee.employee_name = name;
END;

# CALL调用OUT参数,要传 变量(@变量名)而不是普通变量名。

-- 先定义一个变量用来接收输出
SET @salary = 0;

-- 再调用存储过程
CALL GetSalaryByName('王强', @salary);

-- 最后查看输出的工资
SELECT @salary;
(6)创建带 INOUT 参数的存储过程
sql 复制代码
CREATE PROCEDURE GetNameSalary(INOUT name_salary DECIMAL(10,2))
BEGIN
  SELECT salary INTO name_salary
  FROM Employee
  WHERE employee_name = '张强'  -- 这里可以改成动态的
  LIMIT 1;
END;

-- 先定义变量
SET @salary = 0;

-- 调用存储过程
CALL GetNameSalary(@salary);

-- 查询变量
SELECT @salary;

/*
传一个值进去 name_salary,虽然进来的值是什么无所谓。

存储过程内部会把张强的工资查出来,重新赋值给 name_salary。

最后 name_salary就变成了工资。
*/

二、修改、查看、删除

2.1 查看全部
sql 复制代码
SHOW CREATE PROCEDURE MaxSalary
2.2 查看存储过程\函数的状态信息
sql 复制代码
SHOW PROCEDURE STATUS;  # 查看全部

SHOW PROCEDURE STATUS LIKE 'MaxSalary'; # 查看某一个存储过程

SHOW FUNCTION STATUS LIKE 'MaxSalary'; # 查看某一个函数
2.3 从information_schema.Routines表中查看存储过程和函数的信息

ROUTINES 视图不仅可以查到过程/函数的名字、类型,还能看到比如定义者、创建时间、安全类型、具体定义体(ROUTINE_DEFINITION)等信息。
SELECT * FROM information_schema.ROUTINES
WHERE ROUTINE_NAME = 'MaxSalary' AND ROUTINE_TYPE = 'PROCEDURE';

2.4 修改

修改存储过程或函数,不影响存储过程或函数功能,只是修改相关特性。使用ALTER语句实现

2.5 删除

因为 MySQL 不支持直接修改存储过程,所以最常见的方法是:先删除(DROP),再重新创建(CREATE)

sql 复制代码
-- 删除已有存储过程
DROP PROCEDURE IF EXISTS MaxSalary;

-- 重新创建
DELIMITER //

CREATE PROCEDURE MaxSalary()
BEGIN
    -- 新的逻辑代码
END //

DELIMITER ;

# DELIMITER 用来告诉 MySQL 现在用 // 作为结束符,避免中间的 ; 提前结束。

三、结语

风浪还没停歇,我宣告奔跑的意义

须知少日拏云志,曾许人间第一流。我们还年轻,我们还有无限可能!

相关推荐
不羁。。13 分钟前
【撸靶笔记】第八关:GET - Blind - Boolian Based - Single Quotes
数据库·sql·mybatis
AwhiteV1 小时前
利用图数据库高效解决 Text2sql 任务中表结构复杂时占用过多大模型上下文的问题
数据库·人工智能·自然语言处理·oracle·大模型·text2sql
m0_595199851 小时前
Redis(以Django为例,含具体操作步骤)
数据库·redis·缓存
爱尚你19931 小时前
MySQL 三大日志:redo log、undo log、binlog 详解
数据库·mysql
ReedFoley2 小时前
【笔记】动手学Ollama 第五章 Ollama 在 LangChain 中的使用 - Python 集成
笔记·langchain
月盈缺2 小时前
学习嵌入式的第二十二天——数据结构——双向链表
数据结构·学习·链表
小猿姐3 小时前
KubeBlocks AI:AI时代的云原生数据库运维探索
数据库·人工智能·云原生·kubeblocks
★YUI★4 小时前
学习游戏制作记录(制作系统与物品掉落系统)8.16
学习·游戏·ui·unity·c#
努力还债的学术吗喽4 小时前
【速通】深度学习模型调试系统化方法论:从问题定位到性能优化
人工智能·深度学习·学习·调试·模型·方法论
NocoBase4 小时前
10 个开源工具,快速构建数据应用
数据库·低代码·开源