MySQL学习---13、存储过程与存储函数

news2025/2/27 14:28:07

1、存储过程概述

MySQL从5.0版本开始支持存储过程和函数。存储过程和函数能够将负杂的SQL逻辑封装在一起,应用程序无序关注存储过程和函数内部复杂的SQL逻辑,而只需要简单的调用存储过程和函数就可以。

1.1 理解

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

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

好处:
1、简化操作,提高了sql语句的重用性,减少了开发程序员的压力。
2、减少操作过程中的失误,提高效率。
3、减少网络传输量(客户端不需要把所有的SQL语句通过网络发给服务器)
4、减少了SQL语句暴露在网上的风险,也提高了数据查询的安全性。

和视图、函数的对比
它和视图有着同样的优点,清晰、安全,还可以减少网络传输量。不过它和视图不同,视图是虚拟表,通常不对底层数据表直接进行操作,而存储过程是程序化的SQL语句,可以直接操作底层数据表,相比于面向集合的操作方式,能够实现一些更复杂的数据处理。
一旦存储过程被创建出来,使用它就和使用函数一样简单,我们直接通过调用存储过程名即可。相较于函数,存储过程是没有返回值的。

1.2 分类

存储过程的参数类型可以是IN、OUT和INOUT。根据这个分类:
	1、没有参数(没有参数没有返回)。
	2、仅仅带IN类型(有参数无返回)。
	3、仅仅带OUT(无参数有返回)。
	4、既带IN又带OUT (有参数有返回)。
	5、带INOUT(有参数有返回)

2、创建存储过程

基本语法:
Create Procedure 存储过程名(IN | OUT | INOUT 参数名 参数类型,...)
[characteristics  ...]
BEGIN
	存储过程体
END

说明:
1、参数前面的符号的意思
(1)IN:当前参数为输入参数,也就是表示入参;存储过程只是读取参数的值。如果没有定义参数种类,默认就是IN,表示输入参数。
(2)OUT:当前参数为输出参数,也就是表示出参;执行完之后,调用这个存储过程的客户端或应用程序就可以读取这个参数返回的值了。
(3)INOUT:当前参数既可以为输入参数,也可以为输出参数。
2、形参类型可以是MySQL数据库中的任意类型。
3、characteristics表示创建存储过程时指定的对存储过程的约束条件,其取值信息如下:

Language SQL
| [not] Deterministic
| {Contains SQL | NO SQL | READS SQL DATA
| MODIFIES SQL DATA}
| SQL SECURITY { DEFINER | INVOKE }
| COMMENT 'string'

Language SQL:说明存储过程执行体式由SQL语句组成的,当前系统支持的语音为SQL。

[Not] Deterministic:指明存储过程执行的结果是否确定。Deterministic表示结果时确定的。每次执行存储过程时,相同的输入都会得到相同的输出。Not Deterministic表示结果时不确定的,相同的输入可能得到不同的输出。如果没有指定任意一个值,默认为Not Deterministic。

{Contains SQL| No SQL |READ SQL DATA|MODIFIES SQL DATA}:指明子查询使用SQL语句的限制。
(1)Contains SQL表示当前存储过程的子程序包含SQL语句,但是并不包含读写数据的SQL语句。
(2)NO SQL 表示当前存储过程的子程序中不包含任何SQL语句。
(3)READS SQL DATA 表示当前存储过程的子查询中包含读数据的SQL语句。
(4)MODIFIES SQL DATA 表示当前存储过程的子查询中包含写数据的SQL语句。
(5)默认情况下,系统会知道为Contains SQL。

SQL SECURITY { DEFINER | INVOKER }:执行当前存储过程的权限,既指明哪些用户能够执行当前存储过程。
(1)Definer表示只有当前存储过程的创建者或者定义者才能执行当前存储过程。
(2)Invoker表示拥有当前存储过程的访问权限的用户能够执行当前存储过程。

4、存储过程体中可以有多余SQL语句,如果仅仅一条SQL语句,则省略Begin和End,编写存储过程并不是一件简单的事情,可能存储过程中需要复杂的SQL语句。
(1)Begin…End:中间可能包含了多个语句,每个语句以(;)号为结束符。
(2)Declare:用来声明变量,使用的位置位于Begin…End语句中间,而且需要在其他语句使用之前进行变量声明。
(3)Set:赋值语句,用于对变量进行赋值。
(4)Select…Into:把从数据表中查询的结果存放到变量中,也就是为变量赋值。
5、需要设置新的结束标志

Delimiter 新的结束标志

说明:因为MySQL默认的语句结束符为分号’;'。为了避免与存储过程中SQL语句结束符相冲突。需要使用Delimiter改变存储过程的结束符。

2.1 案例实操

2.1.1 无参输入和无参输出

1、创建存储过程select_all_data()–查看employees表中的所有数据

在这里插入图片描述
2、调用存储过程select_all_data()
在这里插入图片描述

2.1.2 有参输入和无参输出

1、创建存储过程select_id_101()—打印employee_id为101的用户信息
在这里插入图片描述

2、调用存储过程
在这里插入图片描述

2.1.3 有参输入和有参输出

1、创建存储过程select_salary_id_101()----获取employee_id为101的员工工资;
在这里插入图片描述
2、调用存储过程
在这里插入图片描述
3、查看结果
在这里插入图片描述

2.1.4 有参输入和有参输出(INOUT)

1、创建存储过程select_id_manager_id—获取管理者的id
在这里插入图片描述
2、调用存储过程

在这里插入图片描述
3、查看结果
在这里插入图片描述

3、存储函数概述

其实前面的博客就写了很多函数。使用这些函数可以对数据进行的各种处理操作,极大地提高用户对数据库的管理效率。MySQL支持自定义函数,定义好之后,调用方式和调用MySQL预定义的系统函数一样。
学过的函数:
(1)Length
(2)Substr
(3)Concat

3.1 语法分析

Create Function 函数名(参数名 参数类型,...)
returns 返回值类型
[characteristics]
Begin
	函数体  #函数体一定要有Return语句
END

说明:
(1)参数列表·:指定参数为IN、Out或NOUT只对Procedure是合法的,Function中总是默认为IN参数。
(2)Returns type 表示函数返回数据的类型。Returns子句只能对Function做指定,对函数而言是强制的。它用来指定函数的返回类型,而且函数体必须包含一个Return value语句。
(3)characteristic创建函数时指定的对函数的约束。取值与创建存储过程时相同。
(4)函数体也可以用Begin…End来表示SQL代码的开始和结束。如果函数体只有一条语句,也可以省略Begin…End。

3.2 调用存储函数

select 函数名(实参列表)

3.3 案例实操

3.3.1 无参输入

1、创建存储函数Select_max_salary()–获取员工最高工资的工资
在这里插入图片描述
2、调用函数
在这里插入图片描述

3.3.2 有参输入

1、创建存储函数select_id_salary(uid int)–获取该id的工资
在这里插入图片描述
2、调用函数
在这里插入图片描述

4、对比存储函数和存储过程

关键字调用语法返回值应用场景
存储过程ProcedureCall 存储过程名()理解为有0个或多少一般用于更新
存储函数FunctionSelect 函数名()只能是一个一般用于查询结果为一个字值的返回

5、存储过程和存储函数的查看、修改、删除

5.1 查看

1、使用Show Create语句查看存储过程和函数的创建信息
	基本语法:
Show Create {Procedure | Function} 存储过程名或函数名

举例:
在这里插入图片描述
2、使用Show Status 语句查看存储过程和函数的状态信息
基本语法:

Show {Procedure|Function} Status [like 'pattern']

举例:
在这里插入图片描述
3、从information_schema.Routines表中查看存储过程和存储函数的信息。
基本语法:

select * From information_schema.Routines
where Routine_Name='函数名或过程名' AND Rountine_type='函数或过程'

举例:
在这里插入图片描述

5.2 修改

修改存储过程和存储函数,不影响存储过程或函数功能,只是修改特性。使用Alter语句实现。
alter {Procedure | Function } 存储过程或函数的名 [characteristic]

5.3 删除

删除存储过程和函数可以使用Drop语句。
基本语法:
Drop {Procedure | Function } [if exists] 存储过程或函数名

6、存储过程的优缺点

6.1 优点

1、存储过程可以一次编译多次使用
2、可以减少开发工作量
3、存储过程的安全性强
4、可以减少网络传输量
5、良好的封装性

6.2 缺点

1、可移植性
2、调试困难
3、存储过程的版本管理很困难
4、不适合高并发的场景

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ASEMI代理LTC2954CTS8-2#TRMPBF原装ADI车规级芯片

编辑:ll ASEMI代理LTC2954CTS8-2#TRMPBF原装ADI车规级芯片 型号:LTC2954CTS8-2#TRMPBF 品牌:ADI/亚德诺 封装:TSOT-23-8 批号:2023 引脚数量:23 工作温度:-40C~85C 安装类型&#xff1a…

若依框架(RuoYI)项目打包(jar)方法,部署到 Linux 服务器

序言 在若依框架的 bin 目录下,存在着三个 bat 文件,一个是清除之前的依赖的自动化 bat 脚本(clean.bat),一个是自动化项目打包的 bat 脚本(package.bat),一个是运行若依项目的脚本…

云原生CAx软件:技术约束

Pivotal公司的Matt Stine于2013年首次提出Cloud Native(云原生)的概念,从概念提出到技术落地,云原生还处于不断发展过程中,关于云原生的定义也不断在完善。 云原生为使用开源软件堆栈来创建容器化、动态编排和面向微服务的应用程序。 Heroku创…

YOLOv8 深度解析!一文看懂,快速上手实操(附实践代码)

关注并星标 从此不迷路 计算机视觉研究院 公众号ID|ComputerVisionGzq 学习群|扫码在主页获取加入方式 开源地址:https://github.com/ultralytics/ultralytics 计算机视觉研究院专栏 作者:Edison_G YOLOv8 是 ultralytics 公司在 …

消息队列测试场景和redis测试场景

一、消息队列测试场景 1、什么是消息队列。你是怎么测试的? 解题思路: 什么是消息队列。 消息队列应用场景。 消息队列测试点列举。 2、什么是消息队列 Broker:消息服务器,提供消息核心服务 Producer:消息生产者&a…

Python入门(八)字典(一)

字典(一) 1.字典概述2.一个简单的字典3.使用字典3.1 访问字典中的值3.2添加键值对3.3 先创建一个空字典3.4 修改字典中的值3.5 删除键值对 作者:xiou 1.字典概述 在本章中,你将学习能够将相关信息关联起来的Python字典&#xff…

二叉排序树查找成功和不成功的平均查找长度

理解二叉树的特性: 1)结点:包含一个数据元素及若干指向子树分支的信息。 2)结点的度:一个结点拥有子树的数据成为结点的度。 3)叶子结点:也称为终端结点,没有子树的结点或者度为零的结点。 4)分支结点:也称为非终端结点,度不为零的结点成为非终端结点。 5)结点…

视觉检测设备主要有哪几分类

在如今的工业4.0时代,整个行业都在加速智能制造的脚步,此时我们就不得不说其其中重要的环节——视觉检测,本身其只是属于机器视觉中一个应用的分支,但是因其应用广泛,久而久之很多工厂行业的从业者在遇到需要外观检测问…

GDB 的简单使用

GDB 的简单使用 一、启动调试二、常用调试命令1.list(显示程序源代码)2.break、tbreak、delete、disable、enable 和 info break(断点操作)3.run(运行源程序)4.next 和 step(单步调试&#xff0…

大型语言模型 (LLM) 的两条发展路线:Finetune v.s. Prompt

前言 如果你对这篇文章感兴趣,可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。 在大型语言模型的研究中,研究者对其有两种不同的期待,也可以理解为是两种不同的路线,具…

【LeetCode: 494. 目标和 | 暴力递归=>记忆化搜索=>动态规划 | 背包模型】

🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

【Spring框架三】——Spirng IOC和DI的实现

系列文章目录 【Spring框架一】——Spring框架简介 Spirng IOC和DI的实现 系列文章目录前言一、IDEA新建Spring 项目二、使用XML文件的方式实现IOC和DI1.创建XML文件2. 通过构造函数的方式进行注入运行结果3.setter方法进行注入 三、使用注解的方式实现IOC和DISpring 5中的常用…

Django SQL注入漏洞 CVE-2022-28346

漏洞简介 Django 在2022年发布的安全更新&#xff0c;修复了在 QuerySet 的 annotate()&#xff0c; aggregate()&#xff0c; extra() 等函数中存在的 SQL 注入漏洞。 影响版本 2.2< Django Django <2.2.283.2< Django Django <3.2.134.0< Django Django <4…

Hadoop 4:Hive

数据仓库概念 数据仓库&#xff08;英语&#xff1a;Data Warehouse&#xff0c;简称数仓、DW&#xff09;,是一个用于存储、分析、报告的数据系统。 数据仓库的目的是构建面向分析的集成化数据环境&#xff0c;分析结果为企业提供决策支持&#xff08;Decision Support&#x…

新版Mamba体验超快的软件安装

在一文掌握Conda软件安装&#xff1a;虚拟环境、软件通道、加速solving、跨服务器迁移中详细介绍的conda的基本使用和遇到问题的解决方式&#xff0c;也提到了mamba作为一个替代工具&#xff0c;可以很好的加速conda的solving environemnt过程。但有时也会遇到一个很尴尬的问题…

苹果笔要不要买?apple pencil的平替笔推荐

第一款ipad在10年前就已经出现了&#xff0c;它被用作平板电脑&#xff0c;功能非常强大。而现在&#xff0c;ipad的产品型号更新速度&#xff0c;也让ipad变得更加受欢迎。在这些设备中&#xff0c;ipad的辅助配件扮演着重要角色&#xff0c;比如今天我们要讲的这款电容笔&…

【LeetCode】《LeetCode 101》第八章:分治法

文章目录 8.1 算法解释8.2 表达式问题241. 为运算表达式设计优先级&#xff08;中等&#xff09;932. 漂亮数组&#xff08;中等&#xff09;312. 戳气球&#xff08;困难&#xff09; 8.1 算法解释 分治问题 通过「把原问题分为子问题&#xff0c;再将子问题进行合并处理」&a…

伙伴匹配推荐接口的优化策略【优先队列+多线程分批处理,java实现】

文章目录 接口背景接口问题说明优化策略用户匹配度计算接口改进与测试说明改进前改进一&#xff08;使用优先队列存储编辑距离较小的n个元素&#xff09;改进二&#xff08;使用优先队列存储编辑距离较小的n个元素数据分批查询、分批处理&#xff09;改进三&#xff08;使用优先…

算法修炼之练气篇——练气十九层

博主&#xff1a;命运之光 专栏&#xff1a;算法修炼之练气篇 前言&#xff1a;每天练习五道题&#xff0c;炼气篇大概会练习200道题左右&#xff0c;题目有C语言网上的题&#xff0c;也有洛谷上面的题&#xff0c;题目简单适合新手入门。&#xff08;代码都是命运之光自己写的…

互联网本来很简单,但为啥人们看的那么复杂

昨天有朋友问我互联网&#xff0c;说互联网怎么怎么创新。 我说你看到的都是像。佛说佛有十万身。这都是像&#xff0c;不是相。 &#xff08;1&#xff09; 500多年前&#xff0c;意大利美第奇家族为了给教皇运送全欧洲信民们的捐赠&#xff0c;所以建立了一张天网一张地网。天…