数据的创建、调用、修改、删除存储过程,以及第一类丢失更新(回滚丢失)和 第二类丢失更新(覆盖丢失/两次更新问题)

本文主要是介绍数据的创建、调用、修改、删除存储过程,以及第一类丢失更新(回滚丢失)和 第二类丢失更新(覆盖丢失/两次更新问题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据的创建存储过程、调用存储过程、修改存储过程、删除存储过程,以及第一类丢失更新(回滚丢失)和 第二类丢失更新(覆盖丢失/两次更新问题)

文章目录

  • 一、创建存储的语法
  • 二、调用存储过程
  • 三、修改存储过程
  • 四、删除存储过程
  • 五、**第一类丢失更新**(回滚丢失)
  • 六、**第二类丢失更新**(覆盖丢失/两次更新问题)


提示:以下是本篇文章正文内容,下面案例可供参考

一、创建存储的语法

CREATE PROCEDURE 过程名称( [ [输入输出类型] 参数名 参数类型(宽度) , ... ] ) 
BEGINSQL语句块
END $

其中输出输入的参数类型有以下三种:

  • IN :表示输入参数

    • 仅能从存储过程的调用者向存储过程传递数据(即由外向内传递)
  • OUT :表示输出参数

    • 仅能从存储过程内部将数值传递给存储过程的调用者(即由内向外传递)
  • INOUT :表示输入输出参数

    • 既能从存储过程的调用者向存储过程传递数据(即由外向内传递)
    • 又能从存储过程内部将数值传递给存储过程的调用者(即由内向外传递)
mysql> CREATE PROCEDURE register(IN userName VARCHAR(20),IN userPass VARCHAR(20),OUT userId INT)-> BEGIN-> INSERT INTO UserInfo(userName,userPass)VALUES(userName,userPass);-> SELECT LAT_INSERT_ID() INTO userId;-> END $

在这里插入图片描述
其中:

mysql> DELIMITER $

是来修改 定界符

之后遇到修改后的定界符就表明语句结束(因为语句中有原本的分界符,会冲突),等到存储过程创建完毕则需要将 定界符 修改为默认的 ;

DELIMITER ;

二、调用存储过程

在 MySQL 中调用存储过程可以通过 CALL 命令来实现:
代码如下(示例):

CALL 过程名称( [实参列表] )

根据实际情况为 存储过程 传递参数。

如果参数类型为 OUTINOUT 则需要定义变量并将变量作为存储过程的参数使用。

三、修改存储过程

代码如下(示例):

ALTER PROCEDURE 过程名称 [特征];
mysql> ALTER PROCEDURE register;

在这里插入图片描述

四、删除存储过程

通过 drop procedure 命令可以删除存储过程:

DROP PROCEDURE [IF EXISTS] 过程名称;

五、第一类丢失更新(回滚丢失)

隔离级别较高的:
在这里插入图片描述
隔离级别较低的:
在这里插入图片描述
但在MySQL数据库,任何隔离级别不允许第一类更新丢失。

六、第二类丢失更新(覆盖丢失/两次更新问题)

隔离级别较高的:
在这里插入图片描述
隔离级别较低的:
在这里插入图片描述
第二类丢失更新原因:MySQL可重复读默认采用的是快照读。快照读的一个问题也就是没有办法获取最新的数据。所以快照读是第二类更新丢失的一个主要原因。


这篇关于数据的创建、调用、修改、删除存储过程,以及第一类丢失更新(回滚丢失)和 第二类丢失更新(覆盖丢失/两次更新问题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/576737

相关文章

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当