事务四大特性

news2024/11/15 13:53:15

没有开启事务的话直接提交、修改数据,有事务则进行两阶段提交:

①原子性

undolog 来实现一旦失败就马上触发回滚

当前事务是不可再分的,要么一起执行,要么都不执行。 start transaction

redolog日志池存储undolog日志,事务依次提交到undolog日志,undolog没有问题就一起commit数据(更改数据),有问题(其中任何一条)的话就不提交。

②持久性

事务一旦提交它对数据库的改变就是永久的

造成持久性危机的是因为两段式提交,我们不能因为数据库的故障(比如断电)就对数据的改变发生影响。

解决办法:在数据更改之前加上数据缓冲池(Buffer pool),undolog日志打印到缓冲池,数据端向缓冲池中进行定时刷脏来改变数据,如果错误被解决以后,那么数据就会改变(undolog日志有问题没有执行的话,sql语句将不会执行)。

例如断电之后,来电时日志中的东西会通过commit提交到数据库当中;

没有事务的话,语句会放到缓存池里,每隔一段时间提交一份数据到数据库中,一旦断电,数据就会丢失。

③隔离性

并发执行的事务是不会相互干扰的(A、B两个事务同时对数据库进行操作)

隔离性的隔离级别:(隔离级别越高,解决并发产生的问题越多)

1、读未提交 read uncommitted

2、读已提交 read committed

3、可重复读 repeatable read

4、串行化 serializable

事务的并发问题:

1、读未提交---脏读:事务A读取到了事务B修改但是还没有提交的数据。(读取到了undolog中刷脏前的数据)

读已提交解决了脏读的现象,但会造成不可重复读的现象

2、读已提交---不能重复读:事务A多次查询到的结果不一致。(事务A读取到了事务B提交后的数据,对于事务A来说读取数据在事务B提交之前和之后是不一样的)(Orcal)

可重复度解决了不能重复读的现象,但会造成幻读的现象

3、可重复度---幻读:当事务A要求全部查询表当中的数据,与此同时事务B对表进行了增删改操作,那么对于事务A来说,查询不到事务B的任何操作,就跟出现幻觉一样。(Mysql)

如何解决幻读?串行化

4、串行化---解决了上边的问题---> 让事务一个一个的执行(串行执行)。只有a提交之后b才能查询出来,等待提交过程中b一直都在等待。

(缺点:吞吐量太小)

mysql:设置的可重复读

oracal:设置的不可重复度

④一致性

(最后的保障,前面3个性质都是为了保证一致性)

事务结束时,数据库完整性不会得到破坏【转账总额不变】

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

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

相关文章

【Android OpenCV】Visual Studio 创建支持 OpenCV 库的 CMake 工程 ④ ( OpenCV 官方代码示例 )

文章目录一、OpenCV 官方代码示例1、Windows 平台代码示例2、Android 平台代码示例参考 【Android OpenCV】Visual Studio 创建支持 OpenCV 库的 CMake 工程 ① ( 下载 OpenCV 库 | Windows 中安装 OpenCV 库 ) 博客 , 可下载 OpenCV 库 ; CSDN 下载地址 : https://download.c…

educoder数据结构 字符串匹配 第2关:实现KMP字符串匹配

本文已收录于专栏 🌲《educoder数据结构与算法_大耳朵宋宋的博客-CSDN博客》🌲 任务描述 本关的编程任务是补全 step2/kmp.cpp 文件中的KmpGenNext函数,以实现 KMP 字符串匹配。该函数生成给定字符串的next数组。 相关知识 第 1 关中实现…

LEETCODE 19. 删除链表的倒数第 N 个结点

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 示例 1: 输入:head [1,2,3,4,5], n 2 输出:[1,2,3,5]示例 2: 输入:head [1], n 1 输出:[]示例 3:…

shell流程控制之条件判断练习案列

练习案例1、判断当前磁盘剩余空间是否有20G,如果小于20G,则将报警邮件发送给管理员,每天检查一次磁盘剩余空间。2、判断web服务是否运行(1、查看进程的方式判断该程序是否运行,2、通过查看端口的方式判断该程序是否运行…

memcpy与memmove函数的区别和实现

1.函数定义 memcpy与memmove都是C语言的库函数,在头文件string.h中,作用是内存拷贝。唯一的区别是,当内存发生局部重叠时,memmove保证了拷贝的结果是正确的,但是memcopy不一定是正确的。但是memcpy比memmove速度快。 …

zookeeper学习笔记3(小滴课堂)

zk集群核心知识之三种角色及其作用: 注册中心的三种模式: 选举核心概念及选举状态: 选举发生的时机及选举算法: zookeeper集群的搭建: 我们先来启动三台虚拟机: 然后我们来修改一下我们的zookeeper配置&a…

Introducing Tome, AI讲演助手

随着ChatGPT进入人们的视野,AI开始在越来越多的领域大展拳脚,近期,一款名为Tome的讲演编辑工具(类似幻灯片)推出了AI辅助创作的功能, Tome的AI讲演功能可以更轻松地将文本、图像、音频等多种媒体元素融合到…

CPU缓存一致性协议MESI

目录 CPU高速缓存(Cache Memory) CPU为何要有高速缓存 带有高速缓存的CPU执行计算的流程 目前流行的多级缓存结构 多核CPU多级缓存一致性协议MESI MESI协议缓存状态 MESI状态转换 多核缓存协同操作 单核读取 双核读取 修改数据 同步数据…

“英雄无敌”(一)

注意:在阅读本文前建议观看对应的视频教程,本文主要作为那些对视频教程仍有疑问的学习者的参考资料。且本文的部分内容有些过时(如仍使用旧版Unity的动画系统),故直接阅读本文对Unity的学习没有太大意义 视频教程&…

写小论文心得(计算机视觉领域)

简介 这篇博文打算讲一下我写小论文前后的过程,其中有许多地方我觉得对于新手来说还是有很多帮助的,包括我自己也是自己慢慢摸索出来的,希望能对正在准备自己第一篇论文的人有所帮助。 写论文的整个过程我想分为几个阶段: 1.获得…

【深度学习】生成对抗网络(GAN)生成海贼王图像 + PyTorch代码实现

文章目录一、数据集介绍1.1 lufei(路飞)1.2 luobin(罗宾)1.3 namei(娜美)1.4 qiaoba(乔巴)1.5 shanzhi(山智)1.6 suolong(索隆)1.7 wu…

【内核笔记】2022回顾-2023规划

文章目录一、2022博客总结二、2023博客规划三、改进沉淀、分享、成长,让自己和他人都能有所收获!😄 一、2022博客总结 2022年重点优化了🚀RK3399平台开发入门到精通系列专栏,订阅量突破2100个订阅2022年浏览量破190万2…

《梁启超家书》笔记三——交友取益,或读书取益,也要方面稍多,才有接谈交换,或开卷引进的机会

目录 1、学科选择建议 2、学习 3、所学不可太专向(不知道学科外其他方向的了) 4、建议欧游实地开开眼界 5、建议结婚前分开两地住 6、毕业后工作看法(分析利弊) 7、处事态度与人生观 1、学科选择建议 我很想你以生物学为主科,因为它是…

Vue(五)

1. 绑定class和style样式 dom里自己拿到节点,改它上面的class样式 shift()移除第一个class属性 push想加哪个class属性都行 59行div知道自己只能用两个样式,四种情况 上面这种不合法,就算把样式加进div也得 样式对象:里面的key绿…

【ElasticSearch7.X】学习笔记(一)

【ElasticSearch7.X】学习笔记一、介绍1.1、ElasticSearch1.2、RESTful1.3、数据格式二、下载安装(单机部署)2.1、解压文件2.2、修改配置配置2.3、创建用户并授权2.5、启动三、增删查改3.1、 索引操作3.1.1、增加索引3.1.2、查看索引3.1.2.1、查看所有索…

定时任务介绍及X-Job和E-Job简单对比

下面对elastic-Job和xxl-Job做个简单的描述和对比 一、区别 1、XJob环境依赖于mysql,不依赖ZooKeeper, 2、EJob依赖ZooKeeper1、X-Job 侧重的业务实现的简单和管理的方便,学习成本简单, 失败策略和路由策略丰富。推荐使用在“用户…

对elasticsearch的实际应用

有业务需求,要做一个搜索接口,从千万的数据中根据筛选项查到需要的数据 筛选项有 1.学段。高中,初中等 2.学科。数学,语文等 3.专区。同步专区,高考专区等 4.试卷类型。月考卷,期中考试卷等 5.年级。高一&a…

MyBatis-Plus常用注解

常用注解 TableName 在使用MyBatis-Plus实现基本的CRUD时,我们并没有指定要操作的表,只是在Mapper接口继承BaseMapper时,设置了泛型User,而操作的表为user表 由此得出结论,MyBatis-Plus在确定操作的表时,…

基于 Tensorflow 2.x 从零训练花卉图像识别模型

一、数据集准备 本篇文章使用数千张花卉照片作为数据集,共分为5个分类:雏菊(daisy)、蒲公英(dandelion)、玫瑰(roses)、向日葵(sunflowers)、郁金香&#xf…

ClickHouse中的数据类型

ClickHouse中的数据类型数据类型说明数值类型IntFloatDecimal字符串类型StringFixedStringUUID时间类型DateDateTimeDateTIme64复杂类型ArrayEnumTupleNested特殊类型IPV4GEOBoolean 和 Nullable[参考文章]: ClickHouse | 数据类型介绍 数据类型说明 …