带你深入了解数据库的事务

为什么要使用事务

日常开发中,很多操作,不是通过一个SQL就能完成的,往往需要多个SQL配合完成
当执行多个SQL操作的时候,如果中间出现了特殊的情况(程序崩溃,系统奔溃,网络断开,主机掉电了……)可能就会出现前面的SQL执行成功,后面的SQL执行失败了

联系现实: 转账的时候,数据丢失
在这里插入图片描述
解决方案:使用事务来控制,保证以上两句SQL要么全部执行成功,要么全部执行失败
使用事务可以确保数据库中的一组操作要么全部成功,要么全部失败。这样可以保持数据库中的数据一致性。

事务的概念

事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败。
在不同的环境中,都可以有事务。对应在数据库中,就是数据库事务。


事务的四大特性

在这里插入图片描述

原子性❤️❤️

定义:把多个操作,打包成一个整体称为"原子性"

事务,把多个操作,打包成一个整体,能够保证,这个整体要么都执行成功,要么就一个都不执行
从而有效避免,部分执行,部分未执行,产生的一些"中间状态引起的问题"

这里的都不执行不是真的不执行
当事务中的若干个 sql 语句在一条一条的执行的,事务能够保证,当执行到某一条的时候如果出现问题了。
数据库就能够自动的把前面 sql 造成的影响,给恢复回去,恢复如初,看起来就好像一条SQL都没执行的样子。(把这里的“翻新"的操作,称为"回滚" (rollback))

数据库事务的原子性,核心就是通过"回滚"机制来保证的

回滚实现的机制
为了实现回滚机制,数据库会在执行事务的时候,记录日志.
当事务最终都执行完毕,中间没有差错,这些记录的内容就可以不要了,
但是如果执行事务的过程中,出现问题了, mysql就可以根据日志中记录的内容,来进行恢复操作.

  1. 之前进行了新增操作,就把数据删除掉.
  2. 之前进行了删除操作,就把数据新增上来
  3. 之前进行了修改操作,就把数据改回去
  4. 之前是查询操作,不影响,不需要任何恢复行为.

一致性❤️

定义:执行事务之前,和执行事务完毕之后,数据是一致的(不会出现这种"对不上"的情况),是对数据正确的承诺

持久性也是和回滚有关的:
一旦触发回滚了,回滚回去的数据得是对的.
如果顺利执行没有触发回滚,数据也是要符合要求的.

联系现实体会数据一致性的重要性:
每个公司都有专门的会计岗位负责公司的账目,如果账目对不上,会计可能就会进去;
每个月的生活费,自认为没买什么东西,结果却是还没到月底,就没生活费了,剩余的时间就会很难熬,你心中关于生活费的记录和实际记录对不上,也就是数据的不一致


持久性❤️

定义:此处的持久指的是 程序重启/主机重启,数据仍然能存在

执行事务对数据库产生的修改,就会在硬盘上持久保存重启之后仍然存在;
如果存储在内存中,就不是持久的,内存中的数据会随着程序重启/主机重启而消失

至于 mysql 是如何提交后的事务一定会落到硬盘上的,这背后的原理是十分复杂的((#’^.^# say: 你们的博主不会))


隔离性 ❤️❤️❤️

定义:描述的是,数据库并发执行事务时,产生的情况
并发:多个客户端,同时给服务器,发起事务

每个客户端什么时候把事务提交过来?? 是不知道的,
很可能多个客户端正好就把事务赶到一块了,就需要数据库服务器都能给出处理,更糟糕的是,如果这多个事务都尝试操作同一个表,情况就会更复杂。
数据库服务器就需要把这多个事务都能处理好,就类似于一心多用

联系现实来理解
就是一个餐馆,来了好几桌客人,每一桌客人都点了不同的菜,就需要确保每一桌都能够提供正确的服务,也要在正确的前提下,尽可能的提高效率

数据库一个一个处理事务,处理的速度会比较慢,如果要是一起同时处理,又会诞生出新的问题,
由此产生的三个典型问题

  1. 脏读问题:事务B读到了事务A中未提交的临时数据(脏数据) => 解决:写加锁
  2. 不可重复读:事务B读的过程中,又有一个事务C对刚才事务A提交的数据进行了修改,使事务B内部不同的读操作读到的结果不同 => 解决:读加锁
  3. 幻读:和不可重复读类似,事务B读的过程中,事务C没有修改数据内容,而是修改了“结果集",导致B内部不同的读操作读到的结果集合不同 => 解决:串行化

注:关于并发执行事务过程中产生的三个典型问题这部分内容,后面博主会再写一篇博客进行阐述,并把博客链接放在文章末尾。

博主(#^.^#):创作不易,动动你们的小手 点赞,收藏 + 关注哟!😍😍😍

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

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

相关文章

java数据结构与算法刷题-----LeetCode1005. K 次取反后最大化的数组和(这就不是简单题)

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 卷来卷去,把简单题都卷成中等题了 文章目录 1. 排序后从小到大…

Spring Boot 实现程序的优雅退出

🏷️个人主页:牵着猫散步的鼠鼠 🏷️系列专栏:Java全栈-专栏 🏷️个人学习笔记,若有缺误,欢迎评论区指正 目录 前言 优雅停机是什么 SpringBoot如何实现优雅停机 合理杀死进程 法一&…

SQLiteC/C++接口详细介绍之sqlite3类(十八)

返回目录:SQLite—免费开源数据库系列文章目录 上一篇:SQLiteC/C接口详细介绍之sqlite3类(十七) 下一篇:SQLiteC/C接口详细介绍sqlite3_stmt类(一) ​ 56.sqlite3_update_hook 函数功能&am…

C++面试宝典第36题:骑士游历

题目 在国际象棋的棋盘上,使一个骑士遍历所有的格子一遍且仅一遍。对于任意给定的顶点,输出一条符合上述要求的路径。骑士的走法和中国象棋的马的走法一样,走日。 解析 本题是一个经典的回溯搜索问题,具体来说是求解国际象棋棋盘上骑士的遍历问题,也称为骑士巡游问题(Kni…

【研发日记】Matlab/Simulink技能解锁(四)——在Simulink Debugger窗口调试

文章目录 前言 Block断点 分解Block步进 Watch Data Value 分析和应用 总结 前言 见《【研发日记】Matlab/Simulink技能解锁(一)——在Simulink编辑窗口Debug》 见《【研发日记】Matlab/Simulink技能解锁(二)——在Function编辑窗口Debug》 见《【研发日记】Matlab/Simul…

信驰达车规蓝牙模块RF-BM-2642QB1I赋能汽车T-Box

近年来,随着人们对数据传输需求的增长,传统网络布线的通讯方式逐渐显现出满足不了的局限性,与此同时,各种无线传输技术迅速发展。汽车工业同样需要无线通讯技术,但红外技术、802.11、HomeRF等技术在汽车工业中存在一定…

文献速递:深度学习乳腺癌诊断---使用深度学习改善乳腺癌诊断的MRI技术

Title 题目 Improving breast cancer diagnostics with deep learning for MRI 使用深度学习改善乳腺癌诊断的MRI技术 01 文献速递介绍 乳腺磁共振成像(MRI)是一种高度敏感的检测乳腺癌的方式,报道的敏感性超过80%。传统上,其…

医药工厂5G智能制造数字孪生可视化平台,推进医药企业数字化转型

医药工厂5G智能制造数字孪生可视化平台,推进医药企业数字化转型。随着科技的不断发展,数字化转型已成为医药企业不可或缺的一部分。5G智能制造医药工厂数字孪生可视化平台作为数字化转型的重要工具,正在逐步改变医药企业的生产方式和管理模式…

软考真题详解-系统架构设计师-计算机基础知识(1)

题目1:计算机系统中硬件层之上的软件通常按照三层来划分,如下图所示,图中①②③分别表示(1)。 A.操作系统、应用软件和其他系统软件 B.操作系统、其他系统软件和应用软件 C.其他系统软件、操作系统和应用软件 D.应…

中国银行信息系统应用架构发展历程

概述: 从 20 世纪 80 年代开始至今,我国银行业信息化历程已 有四十年历史。虽然相对于发达国家来讲,我国银行业务信 息化起步较晚,但发展速度很快, 目前我国一些大型商业银行的信息化程度已经处于全球领先水平。 “银行…

Python Web开发记录 Day13:Django part7 Ajax入门与案例(任务管理)

名人说:莫道桑榆晚,为霞尚满天。——刘禹锡(刘梦得,诗豪) 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 1、Ajax入门①简介②工作原理③优点④缺点⑤使用…

操作系统知识-操作系统作用+进程管理-嵌入式系统设计师备考笔记

0、前言 本专栏为个人备考软考嵌入式系统设计师的复习笔记,未经本人许可,请勿转载,如发现本笔记内容的错误还望各位不吝赐教(笔记内容可能有误怕产生错误引导)。 本章的主要内容见下图: 1、操作系统的作用…

c++类和对象(二)

c类和对象(二) 1.类的6个默认成员函数 2. 构造函数 3. 析构函数 4. 拷贝构造函数 5. 赋值运算符重载 6. const成员函数 7. 取地址及const取地址操作符重载 1.类的6个默认成员函数 如果一个类中什么成员都没有,简称为空类。 空类中真的什么都…

python中如何解析Html

在最近需要的需求中,需要 python 获取网页内容,并从html中获取到想要的内容。这里记录一下两个比较常用的python库对html的解析。 1. BeautifulSoup 它是一个非常流行的python脚本库,用于解析HTML和XML文档。如果你对 java 很熟悉&#xff…

关于Zookeeper分布式锁

背景 之前说到分布式锁的实现有三种 1、基于数据库实现的分布式锁 2、Redis分布式锁 3、Zookeeper分布式锁 前者redis分布式锁博客已具体介绍,此博客最终决定补齐关于Zookeeper分布式锁的实现原理。 简述 Zoopkeeper,它是一个为分布式的协调服务&…

C#,图论与图算法,图(Graph)广度优先遍历(BFS,Breadth First Search)算法与源代码

1 深度优先算法与 宽度优先遍历 深度优先算法(DFS,Deep First Search)与 宽度优先遍历(BFS,Breadth First Search) 是树、图数据结构的基础性、标准性的遍历算法。 2 深度优先算法(DFS,Deep First Search) 深度优先搜索(DFS)是一种用于搜索图形或树数据结构的算法…

Kafka:分布式消息队列

1. 简介 介绍 Kafka 的概述、优势和劣势,以及应用场景。 2. 基本概念 2.1 架构 一个典型的 Kafka 体系架构包括若干 Producer、若干Broker、若干 Consumer,以及一个ZooKeeper集群。 ZooKeeper是Kafka用来负责集群元数据的管理、控制器的选举等操作的…

本地虚拟机平台Proxmox VE结合Cpolar内网穿透实现公网远程访问

🔥博客主页: 小羊失眠啦. 🎥系列专栏:《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞👍收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默&…

Selenium 自动化 —— Selenium IDE录制、回放、导出Java源码

Hello Selenium 示例 之前我们在专栏的第一篇文章中演示了使用使用Selenium进行百度搜索的Hello world示例。 代码不复杂非常简单: public static void main(String[] args) {WebDriver driver null;try {// 设置Chrome驱动的路径 // System.setPro…

Zynq—AD9238数据采集DDR3缓存千兆以太网发送实验(后记)

2024.03.05: 测试了开发板网线直连电脑可以传输数据。但是通过开发板→交换机→电脑,没有数据传输。通讯采用UDP通讯,一个是无法满足后续对采集数据的傅里叶变换和傅里叶逆变换的处理。二是无法通过交换机传输数据。 2024.03.07&#xff1a…