【数据库——MySQL】(15)存储过程、存储函数和事务处理习题及讲解
目录
- 1. 题目
- 1.1 存储过程
- 1.2 存储函数
- 1.3 事务处理
- 2. 解答
- 2.1 存储过程
- 2.2 存储函数
- 2.3 事务处理
1. 题目
1.1 存储过程
-
创建表
RandNumber:字段:id自增长,data int; 创建存储过程向表中插入指定个数的随机数(1-99),但如果插入的数为50,则终止插入。 -
创建存储过程,根据员工的工作时间,如果大于
6年时,将其转到经理办公室工作,并调用该存储过程。 -
创建存储过程,比较两个员工的实际收入,若前者比后者高输出
1,若两者相等输出0,若后者比前者高输出-1,并调用该存储过程。 -
创建存储过程
p(in name char(10),out income decimal(7,2)),计算一个员工的实际收入,并调用该存储过程,将员工 朱骏 的实际收入保存在一个用户变量中。 -
创建存储过程
raise(in edu char(6),in x decimal(5,1))将所有某种学历的员工的收入提高%x, 并调用该存储过程,将所有硕士学历的员工的收入提高10%。
1.2 存储函数
-
创建存储函数
getAver(did int),计算某个部门的平均工资(实际收入); -
调用该函数,显示平均工资最高和最低的部门名称。
1.3 事务处理
设置事务处理为手动提交,建立两个连接。
-
观察
@@transaction_isolation设置为read-uncommited时,脏读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为read-uncommited,开始事务,显示employees表中‘ 王林 ’员工信息;
2)在另一个连接B中,修改‘ 王林 ’的workYear为10年;
3)在连接A中显示employees表的员工信息,观察‘王林’的workYear;
4)在一个连接B中,回滚刚才的修改操作;
5)在连接A中显示employees表的员工信息,观察‘王林’的workYear。 -
观察
@@transaction_isolation设置为read-commited时,不可重复读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为read-commited;
2)开始事务,显示employees表中‘王林’员工信息;
3)在另一个连接B中,修改‘王林’的workYear为10年;
4)在连接A中显示employees表的员工信息,观察‘王林’的workYear;
5)在一个连接B中,提交刚才的修改操作;
6)在连接A中显示employees表的员工信息,观察‘王林’的workYear,提交事务。 -
观察
@@transaction_isolation设置为repeatable-read时,幻读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为repeatable-read;
2)开始事务,显示employees表中所有员工信息,观察记录的数目;
3)在另一个连接B中,在employees表插入一条记录,并提交事务;
4)在连接A中显示employees表的员工信息,观察记录的数目;
5)在连接A中,将所有员工的workYear增加一年,观察被修改的记录的数目;
6)在连接A中提交事务;
8)在连接A再次显示employees表中所有员工信息,观察记录的数目; -
设置
@@transaction_isolation设置为serializable;
重复第3个实验的操作,观察操作中出现的现象。
2. 解答
2.1 存储过程
use yggl;
-
创建表
RandNumber:字段:id自增长,data int; 创建存储过程向表中插入指定个数的随机数(1-99),但如果插入的数为50,则终止插入。drop table if EXISTS `yggl`.`RandNumber`; CREATE TABLE if not EXISTS`yggl`.`RandNumber` (`id` int NOT NULL AUTO_INCREMENT,`data` int NOT NULL,PRIMARY KEY (`id`) );drop PROCEDURE if EXISTS p_RandNumber; delimiter $ create procedure p_RandNumber(in n int) begindeclare temp int;declare i int default(1);set temp = 1 + floor(rand()*99);while i <= n and temp != 50 doinsert into randnumber values (null, temp);set temp = 1 + floor(rand()*99);set i = i + 1;end while; end$ delimiter ;set @n=100; call p_RandNumber(@n); select * from randnumber; -
创建存储过程,根据员工的工作时间,如果大于
6年时,将其转到经理办公室工作,并调用该存储过程。drop PROCEDURE if EXISTS p2; delimiter $ create procedure p2() begindeclare did char(3); # 部门编号declare eid char(6); # 员工编号select departments.DepartmentID into didfrom departmentswhere departments.DepartmentName = '经理办公室';select employees.EmployeeID into eidfrom employeeswhere employees.WorkYear > 6;update employeesset DepartmentID = didwhere employees.EmployeeID in(eid); end$ delimiter ;call p2(); -
创建存储过程,比较两个员工的实际收入,若前者比后者高输出
1,若两者相等输出0,若后者比前者高输出-1,并调用该存储过程。drop PROCEDURE if EXISTS p3; delimiter $ create procedure p3(in mname1 char(10), in mname2 char(10)) begindeclare m1 float; # 第一个人的实际收入declare m2 float; # 第二个人的实际收入declare flag int; # 1,0,-1select salary.InCome - salary.OutCome into m1from salary join employees on salary.EmployeeID = employees.EmployeeIDwhere employees.`Name` = mname1;select salary.InCome - salary.OutCome into m2from salary join employees on salary.EmployeeID = employees.EmployeeIDwhere employees.`Name` = mname2;if m1 > m2 thenset flag = 1;elseif m1 = m2 thenset flag = 0;elseset flag = -1;end if;select flag; end$ delimiter ;call p3('王浩', '伍容华'); -
创建存储过程
p(in name char(10),out income decimal(7,2)),计算一个员工的实际收入,并调用该存储过程,将员工 朱骏 的实际收入保存在一个用户变量中。drop PROCEDURE if EXISTS p; delimiter $ create procedure p(in `name` char(10),out income decimal(7,2)) beginselect salary.InCome - salary.OutCome into incomefrom salary join employees on salary.EmployeeID = employees.EmployeeIDwhere employees.`Name` = `name`;end$ delimiter ;set @c=1; call p('朱骏', @c); select @c; -
创建存储过程
raise(in edu char(6),in x decimal(5,1))将所有某种学历的员工的收入提高%x, 并调用该存储过程,将所有硕士学历的员工的收入提高10%。drop PROCEDURE if EXISTS raise; delimiter $ create procedure raise(in edu char(6), in x decimal(5,1)) beginupdate salaryset salary.InCome = salary.InCome*(1+x/100)where EmployeeID in(select employees.EmployeeIDfrom employeeswhere employees.Education = edu); end$ delimiter ;call raise('硕士', 10);
2.2 存储函数
-
创建存储函数
getAver(did int),计算某个部门的平均工资(实际收入);set GLOBAL log_bin_trust_function_creators = 1; # 一共只需要设置一次drop FUNCTION if exists getAver; delimiter $ create FUNCTION getAver(did int) returns float # 返回某个部门的平均工资(实际收入) begindeclare aver float;select AVG(salary.InCome - salary.OutCome) into averfrom employees join salary on employees.EmployeeID = salary.EmployeeIDwhere employees.DepartmentID = did;return aver; end$ delimiter ; -
调用该函数,显示平均工资最高和最低的部门名称。
# 平均工资最高的部门 select departments.DepartmentName, getAver(departments.DepartmentID) as avg_salary from departments ORDER BY avg_salary desc limit 1; # 平均工资最低的部门 select departments.DepartmentName, getAver(departments.DepartmentID) as avg_salary from departments ORDER BY avg_salary asc limit 1;
2.3 事务处理
设置事务处理为手动提交,建立两个连接。
set @@autocommit = 0;

-
观察
@@transaction_isolation设置为read-uncommited时,脏读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为read-uncommited,开始事务,显示employees表中‘ 王林 ’员工信息;
2)在另一个连接
B中,修改‘ 王林 ’的workYear为10年;
3)在连接
A中显示employees表的员工信息,观察‘王林’的workYear;
4)在一个连接
B中,回滚刚才的修改操作;
5)在连接
A中显示employees表的员工信息,观察‘王林’的workYear。
结论:一个事务
B读取了另一个未提交的并行事务A写的数据。【脏读】 -
观察
@@transaction_isolation设置为read-commited时,不可重复读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为read-commited;
2)开始事务,显示
employees表中‘王林’员工信息;
3)在另一个连接
B中,修改‘王林’的workYear为10年;
4)在连接
A中显示employees表的员工信息,观察‘王林’的workYear;
5)在一个连接
B中,提交刚才的修改操作;
6)在连接
A中显示employees表的员工信息,观察‘王林’的workYear,提交事务。
结论:一个事务A重新读取前面读取过的数据,发现该数据已经被另一个已提交的事务B修改过。【不可重复读】
-
观察
@@transaction_isolation设置为repeatable-read时,幻读的情况。
1)在一个连接A中,设置@@transaction_isolation设置为repeatable-read;
2)开始事务,显示
employees表中所有员工信息,观察记录的数目;
3)在另一个连接
B中,在employees表插入一条记录,并提交事务;
4)在连接
A中显示employees表的员工信息,观察记录的数目;
5)在连接
A中,将所有员工的workYear增加一年,观察被修改的记录的数目;
6)在连接
A中提交事务;
7)在连接
A再次显示employees表中所有员工信息,观察记录的数目;
结论:一个事务重新执行一个查询,返回一套符合查询条件的行, 发现这些行因为其他最近提交的事务而发生了改变。【幻读】
-
设置
@@transaction_isolation设置为serializable;
重复第3个实验的操作,观察操作中出现的现象,即:1)在一个连接
A中,设置@@transaction_isolation设置为serializable;
2)开始事务,显示
employees表中所有员工信息,观察记录的数目;
3)在另一个连接
B中,在employees表插入一条记录,并提交事务;
4)在连接
A中显示employees表的员工信息,观察记录的数目;
5)在连接
A中,将所有员工的workYear增加一年,观察被修改的记录的数目;
6)在连接
A中提交事务;
7)在连接
A再次显示employees表中所有员工信息,观察记录的数目;
结论:对于同一个数据来说,在同一个时间段内,只能有一个会话可以访问,包括SELECT和DML,这样可以避免幻读问题。也就是说,对于同一(行)记录,“写”会加“写锁”,“读”会加“读锁”。当出现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行。【可序列化】
上一篇文章:【数据库——MySQL】(14)过程式对象程序设计——游标、触发器
下一篇文章:【数据库——MySQL】(16)游标和触发器习题及讲解
相关文章:
【数据库——MySQL】(15)存储过程、存储函数和事务处理习题及讲解
目录 1. 题目1.1 存储过程1.2 存储函数1.3 事务处理 2. 解答2.1 存储过程2.2 存储函数2.3 事务处理 1. 题目 1.1 存储过程 创建表 RandNumber :字段:id 自增长, data int; 创建存储过程向表中插入指定个数的随机数(1-…...
FFmpeg:打印音/视频信息(Meta信息)
多媒体文件基本概念 多媒体文件其实是个容器在容器里面有很多流(Stream/Track)每种流是由不同的编码器编码的从流中读出的数据称为包在一个包中包含着一个或多个帧 几个重要的结构体 AVFormatContextAVStreamAVPacket FFmpeg操作流数据的基本步骤 打印音/视频信息(Meta信息…...
1.Linux入门基本指令
个人主页:Lei宝啊 愿所有美好如期而遇 目录 01.ls指令 02.pwd指令 03.cd指令 04.touch指令 05.mkdir指令(重要) 06.rmdir&&rm指令(重要) 07.man指令(重要) 08.cp指令(重要) 09.mv指令(重要) 10.cat指令 nano指令 echo指令 输出重定向 追加重…...
2023腾讯云服务器优惠代金券领取、查询及使用说明
腾讯云代金券领取渠道有哪些?腾讯云官网可以领取、官方媒体账号可以领取代金券、完成任务可以领取代金券,大家也可以在腾讯云百科蹲守代金券,因为腾讯云代金券领取渠道比较分散,腾讯云百科txybk.com专注汇总优惠代金券领取页面&am…...
大华智慧园区管理平台任意密码读取漏洞 复现
文章目录 大华智慧园区管理平台任意密码读取漏洞 复现0x01 前言0x02 漏洞描述0x03 影响平台0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 大华智慧园区管理平台任意密码读取漏洞 复现 0x01 前言 免责声明:请勿利用文章内的相关技术从事非法测试&…...
【C++ 学习 ㉖】- 位图详解(哈希扩展)
目录 一、位图的概念 二、位图的实现 2.1 - bitset.h 2.2 - test.cpp 三、位图的应用 3.1 - 例题一 3.2 - 例题二 一、位图的概念 假设有这样一个需求:在 100 亿个整型数字中快速查询某个数是否存在其中,并假设是 32 位操作系统,4 GB…...
天启科技联创郭志强:趟遍教育行业信数化沟坎,创业智能赛道重塑行业生态
郭志强 天启科技联合创始人 近20年互联网、企业信息化、数字化实施、管理及培训经验。对于集团型企业及初创企业、传统企业及互联网企业的信息化、数字化转型有自己独到的见解和实操经验。具备跨区域、集团化信息规划、解决方案、系统架构及企业流程搭建、优化和技术团队管理能…...
Cuckoo沙箱各Ubuntu版本安装及使用
1.沙箱简介 1.1 沙箱 沙箱是一个虚拟系统程序,允许你在沙箱环境中运行浏览器或其他程序,因此运行所产生的变化可以随后删除。它创造了一个类似沙盒的独立作业环境,在其内部运行的程序并不能对硬盘产生永久性的影响。 在网络安全中ÿ…...
什么是mvvm模式,优点是什么
MVVM(Model-View-ViewModel)模式是一种设计模式。它是一种开发模式,旨在分离用户界面的开发和业务逻辑的开发。MVVM模式将应用程序分为三个部分: Model:它代表应用程序的数据模型和业务逻辑。 View:它代表…...
C/C++ 中的函数返回局部变量以及局部变量的地址?
C/C中,函数内部的一切变量(函数内部局部变量,形参)都是在其被调用时才被分配内存单元。形参和函数内部的局部变量的生命期和作用域都是在函数内部(static变量的生命期除外)。子函数运行结束时,所有局部变量的内存单元会被系统释放。在C中&…...
springboot和vue:七、mybatis/mybatisplus多表查询+分页查询
mybatisplus实际上只对单表查询做了增强(速度会更快),从传统的手写sql语句,自己做映射,变为封装好的QueryWrapper。 本篇文章的内容是有两张表,分别是用户表和订单表,在不直接在数据库做表连接的…...
【Leetcode】 51. N 皇后
按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n ,返回所有不同的 n 皇后问题 的解决方案。 每一种…...
Java数据库连接:JDBC介绍与简单示例
Java数据库连接:JDBC介绍与简单示例 在Java程序中,操作数据库是必不可少的。JDBC(Java Database Connectivity)是Java中用于连接和操作数据库的一种技术。通过JDBC,Java程序可以与各种关系型数据库进行交互࿰…...
智慧茶园:茶厂茶园监管可视化视频管理系统解决方案
一、方案背景 我国是茶叶生产大国,茶叶销量全世界第一。随着经济社会的发展和人民生活水平的提高,对健康、天然的茶叶产品的消费需求量也在逐步提高。茶叶的种植、生产和制作过程工序复杂,伴随着人力成本的上升,传统茶厂的运营及…...
springboot整合pi支付开发
pi支付流程图: 使用Pi SDK功能发起支付由 Pi SDK 自动调用的回调函数(让您的应用服务器知道它需要发出批准 API 请求)从您的应用程序服务器到 Pi 服务器的 API 请求以批准付款(让 Pi 服务器知道您知道此付款)Pi浏览器向…...
类 ChatGPT 模型存在的局限性
尽管类ChatGPT模型经过数月的迭代和完善,已经初步融入了部分领域以及人们的日常生活,但目前市面上的产品和相关技术仍然存在一些问题,以下列出一些局限性进行详细说明与成因分析: 1)互联网上高质量、大规模、经过清洗…...
Nginx的安全控制
安全控制 关于web服务器的安全是比较大的一个话题,里面所涉及的内容很多,Nginx反向代理是安全隔离来提升web服务器的安全,通过代理分开了客户端到应用程序服务器端的连接,实现了安全措施。在反向代理之前设置防火墙,…...
字符串与字符编码 - GO语言从入门到实战
字符串与字符编码 - GO语言从入门到实战 字符串 与其他主要编程语⾔的差异 基本数据类型:string 是基础数据类型,而不是引用类型或指针类型。string 在内存中占用的空间大小是固定的,且只读、不可改变。字节切片:string 是只读…...
12P4375X042-233C KJ2005X1-BA1 CE3007 EMERSON servo controller
12P4375X042-233C KJ2005X1-BA1 CE3007 EMERSON servo controller 我们提供三种不同类别的EDGEBoost I/O模块供选择,以实现最大程度的I/O定制: 数字和模拟输入/输出网络和连接边缘人工智能和存储 利用EDGEBoost I/O实现变革性技术 EBIO-2M2BK EBIO-2M2BK载板支持…...
WPF向Avalonia迁移(四、其他事项)
开发必备 1. Avalonia项目源代码!!!!!!!!!!没有源代码,你连控件的背景色怎么改都找不着!! 2.下载你所使用的版本&#x…...
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...
【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云
目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...
HDFS分布式存储 zookeeper
hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架,允许使用简单的变成模型跨计算机对大型集群进行分布式处理(1.海量的数据存储 2.海量数据的计算)Hadoop核心组件 hdfs(分布式文件存储系统)&a…...
基于 TAPD 进行项目管理
起因 自己写了个小工具,仓库用的Github。之前在用markdown进行需求管理,现在随着功能的增加,感觉有点难以管理了,所以用TAPD这个工具进行需求、Bug管理。 操作流程 注册 TAPD,需要提供一个企业名新建一个项目&#…...
