当前位置: 首页 > news >正文

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

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、不适合高并发的场景

相关文章:

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

1、存储过程概述 MySQL从5.0版本开始支持存储过程和函数。存储过程和函数能够将负杂的SQL逻辑封装在一起,应用程序无序关注存储过程和函数内部复杂的SQL逻辑,而只需要简单的调用存储过程和函数就可以。 1.1 理解 含义:存储过程的英文是Sto…...

Mysql日志管理、备份与恢复

文章目录 一、Mysql日志管理1.mysql日志2.日志种类3.日志的查询4.配置日志文件 二、Mysql备份与分类1.数据备份的重要性 一、Mysql日志管理 1.mysql日志 Mysql的日志默认保存位置为/usr/local/mysql/date,Mysql的日志配置文件为/etc/my.cnf,里面有一个…...

STM32单片机声控语音识别RGB彩灯多种模式亮度可调WS2812彩灯

实践制作DIY- GC0129-语音识别RGB彩灯 一、功能说明: 基于STM32单片机设计-语音识别RGB彩灯 二、功能介绍: STM32F103C系列最小系统板5VUSB电源64个灯珠的WS2812灯板1个开关键(3档亮度调节)1个模式切换键(白灯 红灯…...

高校9大学术工具推荐,一定要用起来哦!

1、文献管理工具:例如EndNote、Mendeley和Zotero,这些工具可以帮助您整理、管理和引用文献。 2、数据分析工具:例如SPSS、R和Python等,用于进行统计分析和数据处理。 3、学术写作工具:例如LaTeX和Microsoft Word&…...

记一次压力测试

性能测试文档 背景 为对产品性能有一定了解,现将产品展开一次性能测试; 环境与工具 本章为基本工具准备及linux命令说明,无先后顺序。 Xshell工具 本文使用Xshell在Windows界面下远程登录linux主机安装Xshell直接全部选择默认选项即可&…...

一个文明是否有竞争力,在很大程度上取决于信息传递的效率。

文章目录 引言I 有效地传递信息1.1 信息传播分类1.2 信息传递的有效性II 科技进步的必要条件和充分条件2.1 能量总量2.2 能量密度2.3 衡量科技成就的大小2.4 科学的诞生的意义:获得叠加式收益引言 科技进步的必要条件是能量总量,而充分条件是能量密度。一个文明是否有竞争力,…...

测试4年,跳槽一次涨8k,我跳了3次···

最近有人说,现在测试岗位初始工资太低了,有些刚刚入行的程序员朋友说自己工资连5位数都没有.....干了好几年也没怎么涨。看看别人动辄月薪2-3万,其实我想说也没那么难。说下如何高效地拿到3w。 1.暂且把刚入行的条件设低些吧,大专…...

Redis 入门教程(简单全面版)

1 安装: 1.1 生产环境安装 注意: 1、如果安装过程有问题可以参考源代码中的 README.md 文件 2、如果服务器只安装一个 redis 通常选择 /usr/local/redis 作为安装目录,如果安装多台则建议带上 服务名称 区分(建议带上 服务名称 区…...

java并发-AQS

当我们使用Java并发编程时,我们经常会听到“AQS”的概念。AQS代表“AbstractQueuedSynchronizer”,是Java并发包中的一个重要组件。AQS提供了一个框架,使得开发者可以轻松地实现各种同步器,例如锁,信号量,倒…...

openAI图像生成开发文档

图像生成 了解如何使用我们的 DALLE 型号 介绍 图像 API 提供了三种与图像交互的方法: 根据文本提示从头开始创建图像根据新的文本提示创建现有图像的编辑创建现有图像的变体 本指南介绍了使用这三个 API 终结点的基础知识以及有用的代码示例。要了解它们的实际…...

Python综合案例—利用tkinter实现计算器的程序

目录 一、导入 tkinter 库 定义全局变量 二、定义回调函数 三、创建窗口对象 四、创建标签控件 五、创建数字按钮 六、创建加、减、乘、除和等于按钮 七、创建清空按钮 八、总结 用Python实现计算器可以让我们更好地理解面向对象编程、GUI 编程和事件驱动编程等概念&a…...

canvas学习笔记

其实还有react还没有学&#xff0c;但是公司技术栈里面有canvas&#xff0c;所以先系统学习一下canvas 一、canvas 简介 ​<canvas> 是 HTML5 新增的&#xff0c;一个可以使用脚本(通常为 JavaScript) 在其中绘制图像的 HTML 元素。它可以用来制作照片集或者制作简单(也…...

Navicat Premium 15安装注教程

Navicat Premium 15安装 准备工作 下载好安装包navicat150_premium_cs_x64和安装完成Navicat Premium 15 链接&#xff1a;https://pan.baidu.com/s/1TJs3pjAXJXhu7-13DJLzpg 提取码&#xff1a;hunk 安装Navicat Premium 15 无脑操作&#xff0c;下一步下一步就行了&…...

yolo v8

这个系列代码被封装的非常的精致&#xff0c;对二次开发不太友好&#xff0c;虽然也还是可以做些调节 模型的导出 有三种方式试过&#xff0c;都可以导出onnx的模型 1. 用yolov8 源码来自&#xff1a;ultralytics\yolo\engine\exporter.py (不固定尺寸) yolo export modelpa…...

2022IDEA的下载、安装、配置与使用

文章目录 1.IntelliJ IDEA 介绍1.2 JetBrains 公司介绍1.2 IntelliJ IDEA 介绍1.3 IDEA 的主要功能介绍1.3.1 语言支持上1.3.2 其他支持 1.4 IDEA 的主要优势&#xff1a;(相较于 Eclipse 而言)1.5 IDEA 的下载地址1.6 官网提供的详细使用文档 2.windows 下安装过程2.1 安装前的…...

实验十 超市订单管理系统综合实验

实验十 超市订单管理系统综合实验 应粉丝要求&#xff0c;本博主帮助实现基本效果&#xff01; 未避免产生版权问题&#xff0c;本项目博主不公开源码&#xff0c;如果您遇到相关问题可私聊博主&#xff01; 一、实验目的及任务 通过该实验&#xff0c;掌握利用SSM框架进行系…...

微服架构基础设施环境平台搭建 -(二)Docker私有仓库Harbor服务搭建

微服架构基础设施环境平台搭建 -&#xff08;二&#xff09;Docker私有仓库Harbor服务搭建 通过采用微服相关架构构建一套以KubernetesDocker为自动化运维基础平台&#xff0c;以微服务为服务中心&#xff0c;在此基础之上构建业务中台&#xff0c;并通过Jekins自动构建、编译、…...

springboot+freemarker+restful

什么是freemarker? FreeMarker是一种模板引擎&#xff0c;它可以用于生成各种类型的文档&#xff0c;比如HTML、XML、PDF、Word等。它可以通过简单的模板语法和数据模型来生成文档内容。与传统的JSP相比&#xff0c;FreeMarker的语法更加简洁和易读&#xff0c;并且可以很好地…...

基于Kubernetes集群构建大中型企业CICD应用平台(1)-- devOps

一、DevOps介绍 软件开发最开始是由两个团队组成&#xff1a; 开发计划由开发团队从头开始设计和整体系统的构建。需要系统不停的迭代更新。 运维团队将开发团队的Code进行测试后部署上线。希望系统稳定安全运行。 这看似两个目标不同的团队需要协同完成一个软件的开发。 …...

什么是模型鲁棒性和泛化能力

目录 1、鲁棒性 2、泛化能力 1、鲁棒性 定义&#xff1a;在统计学领域和机器学习领域&#xff0c;对异常值也能保持稳定、可靠的性质&#xff0c;称为鲁棒性。比如说&#xff0c;计算机软件在输入错误、磁盘故障、网络过载或有意攻击情况下&#xff0c;能否不死机、不崩溃&a…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…...

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする 1、前言(1)情况说明(2)工程师的信仰2、知识点(1) にする1,接续:名词+にする2,接续:疑问词+にする3,(A)は(B)にする。(2)復習:(1)复习句子(2)ために & ように(3)そう(4)にする3、…...

逻辑回归:给不确定性划界的分类大师

想象你是一名医生。面对患者的检查报告&#xff08;肿瘤大小、血液指标&#xff09;&#xff0c;你需要做出一个**决定性判断**&#xff1a;恶性还是良性&#xff1f;这种“非黑即白”的抉择&#xff0c;正是**逻辑回归&#xff08;Logistic Regression&#xff09;** 的战场&a…...

Cesium1.95中高性能加载1500个点

一、基本方式&#xff1a; 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...

【机器视觉】单目测距——运动结构恢复

ps&#xff1a;图是随便找的&#xff0c;为了凑个封面 前言 在前面对光流法进行进一步改进&#xff0c;希望将2D光流推广至3D场景流时&#xff0c;发现2D转3D过程中存在尺度歧义问题&#xff0c;需要补全摄像头拍摄图像中缺失的深度信息&#xff0c;否则解空间不收敛&#xf…...

Java-41 深入浅出 Spring - 声明式事务的支持 事务配置 XML模式 XML+注解模式

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

什么是Ansible Jinja2

理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具&#xff0c;可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板&#xff0c;允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板&#xff0c;并通…...

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...