MySQL事务、四大原则、执行步骤、四种隔离级别、锁、脏读、脏写等

MySQL事务

  • MySQL事务
      • 1.什么是事务?
      • 2.事务的四大原则
      • 3.事务执行的步骤
      • 4、事务的隔离性
      • 5、MySQL中的锁

MySQL事务

模拟一个转账业务:

在这里插入图片描述

上图中的sql语句:
update from table set money = mongey - 100 where name = 'A';
update from table set money = mongey + 100 where name = 'B';

但是如果将A姓名或转B姓名写错就会出现,A的金额减掉了,但是B未增加;或者是A的金额未减掉了,但是B增加了,这样就造成了数据库中数据不一致;而事务恰好能解决这个问题。

1.什么是事务?

事务(Transaction):就是将一组sql语句放在同一批次内执行,如果出现sql语句执行错误,则该批次内的所有sql都将取消执行。MySQL数据库中仅InnoDB和BDB类型的数据库表支持事务。

事务的特点:一个事务中如果有一个数据库操作失败,那么整个事务的所有数据库操作都会操作失败,数据库数据就会回滚到该事务开始之前的状态。

2.事务的四大原则

  • 原子性

数据库中的事务执行作为原子粒度,要么都执行成功,要么都不成功,不存在执行部分成功,部分失败的情况。

  • 一致性

一致性是指事务在执行开始之前和结束之后,数据库的完整性约束没有被破坏,至于中间的过程就没有强行规定,只强调初始状态和结束状态。

  • 隔离性

事务的执行是互不干扰的,一个事务的内部操作及使用的数据对其他并发事务是隔离的,并发执行的各个事物之间不能互相干扰;数据库通过加锁来保证事物之间的隔离性。

  • 持久性

持久性是指,事务执行成功后,无论是提交还是回滚,对数据库中的数据改变都是持久性的。

3.事务执行的步骤

步骤一:关闭MySQL的自动提交(MySQL默认开启的是自动提交;1开启;0关闭)
set autocommit = 0;
步骤二:开启一个事务,标记事务的起始点
start transaction;
步骤三:执行一组sql语句
	update salary set salary = salary + 500 where Sname = '张三';
	update salary set salary = salary - 500 where Sname = '李四';
步骤四或步骤五:向数据库提交事务操作
commit;	
步骤四或步骤五:将事务回滚,所有的数据库操作被取消,数据将回到最初的状态。
rollback;
步骤六:开启MySQL自动提交
set autocommit = 1;

这样就解决了上面转账的问题,只有当A和B都执行成功的时候然后再commit,数据才会被保存进数据库中;有错误rollback数据就会回到初始状态。但是注意,回滚或者提交是人主观控制,有sql语句未执行是主观判断可以提交也是可以的;所有都正确执行是也可以选择回滚。

4、事务的隔离性

事务的隔离性:为了让不同的事物之间不存在相互干扰,就需要对事务的操作进行隔离,事务的隔离性也就是将操作同一数据的事务相互分离开,让操作之间分开有序的执行。

实现事务隔离的方式:通常数据库都是采用锁的机制,保证事务之间的隔离性。

5、MySQL中的锁

锁的分类:

  • 基于锁的属性分类:共享锁(读锁、S锁)、排他锁(写锁、X锁)
  • 基于锁的粒度分类:表锁、行锁(记录锁、间隙锁、临键锁)
  • 基于锁的状态分类:意向共享锁、意向排他锁

事务的并发问题:在事务并发执行的时候,如果不进行事务的隔离,那么就会产生脏读、脏写、重复读、幻读的问题;

  • 脏读: 一个事务读取了另一个事务未提交的数据。

    示例: 事务A修改了一行数据,但尚未提交。事务B读取了这行未提交的数据,然后事务A回滚。此时,事务B读取的数据实际上是无效的,是“脏”的。

  • 脏写: 一个事务覆盖了另一个事务已经提交的数据。

    示例: 事务A修改了一行数据并提交,然后事务B修改了同一行数据并提交。事务B的提交导致了对事务A的修改的丢失,这是一种“脏写”。

  • 重复读:在一个事务内,两次读取同一行数据,但在两次读取之间有其他事务修改了这行数据。

    示例: 事务A读取了一行数据,然后事务B修改并提交了这行数据。接着,事务A再次读取相同的数据,发现数据已经发生了变化。这就是“重复读”。

  • 幻读: 在一个事务内,两次查询返回了不同数量的行,但在两次查询之间有其他事务插入了新的数据。

    示例: 事务A查询某个条件下的所有数据,然后事务B插入了符合该条件的新数据。接着,事务A再次查询相同的条件,发现返回的行数发生了变化,即出现了“幻读”。

事务的隔离级别:

  1. READ_UNCOMMITTED 读未提交
  2. READ_COMMITTED 读提交(不可重复读)
  3. REPEATABLE_READ 可重复读
  4. SERIALIZABLE 串行化

每个隔离级别都针对事务并发问题中的一种或几种进行解决,事务级别越高,解决的并发事务问题也就越多,同时也就意味着家的锁就越多,所以性能也会越差。

事务的隔离级别解决的问题:

隔离级别事务读取事务写入解决问题存在问题
READ_UNCOMMITTED不加锁加写锁脏写脏读、不可重复读、幻读
READ_COMMITTED加读锁(每次select完都会释放读锁)加写锁脏读、脏写不可重复读、幻读
REPEATABLE_READ加读锁(每次select完不会释放锁,而是事务结束后才会释放)加写锁脏读、脏写、不可重复读、幻读(mysql的innodb已经解决)幻读(mysql的innodb不存在)
SERIALIZABLE不论是读还是写所有的事务串行化执行,一个事务的执行必须等其他事务结束

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SEO中的实体:它们是什么以及为什么它们很重要?

从了解搜索历史到区分实体与关键字,真正了解实体是什么,以便获得更有针对性的搜索流量。 关于SEO专业人士应该如何理解,更重要的是,如何利用SEO中的“实体”,存在很多困惑。 我明白这是从哪里来的,尤其是…

免费代理IP:如何获取?有什么风险?有什么性价比高的代理IP?

您可能已经知道,生活中没有什么是真正免费的。代理IP虽然用于保护隐私,但也有非常多代理都是免费的,这对于不想使用付费替代方案的用户来说是一个巨大的优势。在这篇博文中,我们将深入研究免费代理的细节,并评估这把双…

磁盘管理 :逻辑卷、磁盘配额

一 LVM可操作的对象:①完成的磁盘 ②完整的分区 PV 物理卷 VG 卷组 LV 逻辑卷 二 LVM逻辑卷管理的命令 三 建立LVM逻辑卷管理 虚拟设置-->一致下一步就行-->确认 echo "- - -" > /sys/class/scsi_host/host0/scan;echo "- -…

Redis缓存雪崩、缓存击穿、缓存穿透

1. 什么是缓存雪崩 当我们提到缓存系统中的问题,缓存雪崩是一个经常被讨论的话题。缓存雪崩是指在某一时刻发生大量的缓存失效,导致瞬间大量的请求直接打到了数据库,可能会导致数据库瞬间压力过大甚至宕机。尤其在高并发的系统中,…

Springboot使用log4j2日志框架

文章目录 1.pom.xml引入依赖2.配置文件引入log4j2的配置文件3.导入log4j2配置文件4.通过Slf4j注解来使用log.info()等最后 1.pom.xml引入依赖 提示&#xff1a;lombok用于Slf4j注解 <dependency><groupId>org.springframework.boot</groupId><artifactId&…

机器人中的数值优化之牛顿共轭梯度法

欢迎大家关注我的B站&#xff1a; 偷吃薯片的Zheng同学的个人空间-偷吃薯片的Zheng同学个人主页-哔哩哔哩视频 (bilibili.com) 本文ppt来自深蓝学院《机器人中的数值优化》 如何解决Hessian矩阵非正定的情况 求解线性系统需要很精确么 引入截断的机制&#xff0c;如果Hessia…

遥感技术应用于作物类型种植面积估算实例

1.农作物遥感分类 1.1 利用多时相环境星 CCD 数据作物分类识别实验 采用支持向量机分类器进行基于象素遥感影像分类方法。在分类过程中&#xff0c;分别对不同日期的单景环境星数据以及不同日期环境星数据的组合进行分类&#xff0c;以评价环境星在作物分类中的应用潜力&#x…

【C语言】分支与循环语句

什么是语句&#xff1f; C语句可分为以下五类&#xff1a; 表达式语句函数调用语句控制语句 &#xff08;本篇重点介绍&#xff09;复合语句空语句 控制语句用于控制程序的执行流程&#xff0c;以实现程序的各种结构方式。C语言支持三种结构&#xff1a; 顺序结构选择结构循…

MidJourney笔记(9)-daily_theme-docs-describe

/daily_theme 切换 #daily-theme 频道更新的通知。 但我发现在对话框那里,是没有这个命令的: 但官网是有介绍,不知道是不是版本问题还是这个命令已经无效。 但后来,我发现这个命令是要在Midjourney服务对话框那里才有,在我们后面添加的Mid

哈希桶的模拟实现【C++】

文章目录 哈希冲突解决闭散列 &#xff08;开放定址法&#xff09;开散列 &#xff08;链地址法、哈希桶&#xff09;开散列实现&#xff08;哈希桶&#xff09;哈希表的结构InsertFindErase 哈希冲突解决 闭散列 &#xff08;开放定址法&#xff09; 发生哈希冲突时&#xf…

MySQL数据库多版本并发控制(MVCC)

在数据库中&#xff0c;并发控制是确保多个事务能够同时执行&#xff0c;而不会导致数据不一致或冲突的关键机制。多版本并发控制(MVCC)是一种流行的并发控制方法&#xff0c;它可以允许多个事务同时读取同一数据项的不同版本&#xff0c;而不会相互阻塞。本文将讨论MVCC的原理…

【每日一题】LeetCode206.反转链表

个人主页&#xff1a;白日依山璟 专栏&#xff1a;Java|数据结构与算法|每日一题 文章目录 1. 题目描述示例1示例2示例3提示 2. 思路3.代码 1. 题目描述 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例1 输入&#xff1a;head [1…

FreeRTOS任务调度

开启任务调度器 vTaskStartScheduler(); 无参数, 无返回值. 作用是用于启动任务调度器&#xff0c;任务调度器启动后&#xff0c; FreeRTOS 便会开始进行任务调度 . 如果允许了静态创建任务, 则创建空闲任务和创建定时器任务都会变为需要程序员手动实现创建. 1.创建空闲任务(…

成为一名成功的互联网产品经理需要掌握哪些技能?

在现代互联网产业中&#xff0c;产品经理扮演着至关重要的角色。作为产品经理&#xff0c;需要不断地学习和提高自己的技能&#xff0c;以便为用户提供更佳的产品体验。以下是成为一名成功的互联网产品经理所需要掌握的技能&#xff1a; 1.产品设计技能 产品设计是产品经理的…

Linux 线程概念

文章目录 前言线程的概念线程的操作操作的原理补充与说明 前言 ① 函数的具体说明被放在补充与说明部分 ② 只说些基础概念和函数使用 线程的概念 网络回答&#xff1a;Linux 线程是指在 Linux 操作系统中创建和管理的轻量级执行单元。线程是进程的一部分&#xff0c;与进程…

使用数组创建链表的解决方案

因为在创建链表时用到了这种方法&#xff0c;后面发现这种方法创建链表做删除操作时不是很好&#xff0c;就打算删除&#xff0c;但是觉得这种方法可能对部分读者有参考意义&#xff0c;就基于数组创建链表的方法单独发了一篇&#xff0c;完整的~链表五大基础操作的实现方法可参…

2022 年全国职业院校技能大赛高职组云计算正式赛卷第二场-容器云

2022 年全国职业院校技能大赛高职组云计算赛项试卷 云计算赛项第二场-容器云 目录 2022 年全国职业院校技能大赛高职组云计算赛项试卷 【赛程名称】云计算赛项第二场-容器云 【任务 1】容器云平台搭建[5 分] 【任务 2】容器云应用部署&#xff1a; Docker Compose 编排部署[7.0…

Python新手上路:“用Python和Pygame创造你的流星雨”

文章目录 一、前言二、下载安装过程1.官网下载安装包2.安装python过程第一步第二步第三步第四步第五步安装完成 3.简单测试Python3.1 检查 Python 版本号3.2 打开 Python 解释器3.3 输入你的第一个代码3.4 运行 Python 脚本 4.安装Pygame4.1 cmd命令安装Pygame4.2 pip升级4.3 安…

thinkcmf 文件包含 x1.6.0-x2.2.3 已亲自复现

thinkcmf 文件包含 x1.6.0-x2.2.3 CVE-2019-16278 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建漏洞利用 修复建议总结 漏洞名称 漏洞描述 ThinkCMF是一款基于PHPMYSQL开发的中文内容管理框架&#xff0c;底层采用ThinkPHP3.2.3构建。ThinkCMF提出灵活的应用机制&a…

k8s的二进制部署(二)网络

节点部署完成之后,节点的状态都是Notready&#xff0c;所以要部署k8s网络&#xff1a; k8s的网络类型&#xff1a; k8s中的通信模式&#xff1a; pod内部之间容器与容器之间的通信。 在同一个pod中的容器共享资源和网络&#xff0c;使用同一个网络命名空间&#xff0c;可以直…