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

为什么要使用事务

日常开发中,很多操作,不是通过一个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内部不同的读操作读到的结果集合不同 => 解决:串行化

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

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

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

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

相关文章

大数据任务调度平台选型建议

一 背景 数仓建设过程中,随着业务发展, ETL 任务调度越来越多,并且这些任务的形态多种多样。怎么样让大量的 ETL 任务准确的完成调度而不出现问题,甚至在任务调度执行中出现错误的情况下,任务能够完成自我恢复甚至执行…

分治法排序:原理与C语言实现

分治法排序:原理与C语言实现 一、分治法与归并排序概述二、归并排序的C语言实现三、归并排序的性能分析四、归并排序的优化 在计算机科学中,分治法是一种解决问题的策略,它将一个难以直接解决的大问题,分割成一些规模较小的相同问…

前后端分离项目部署服务器教程--实践成功

文章目录 项目介绍流程1租界云服务2通过远程软件连接服务器3部署前后端代码停止功能文件 环境配置1.安装jdk2.安装Nginx3.安装mysql数据库 花了将近一天部署前后端的项目,写一个日志记录一下,话说孰能生巧。明天把服务器恢复初始在部署一下。 项目介绍 …

【Node.js从基础到高级运用】十四、Node.js 错误处理与日志记录

引言 在这篇博客文章中,我们将深入探讨Node.js中的错误处理和日志记录的最佳实践。我们会了解如何在Node.js应用程序中有效地捕获和处理错误,并利用日志库如morgan来记录应用程序的活动和错误信息。 第1部分:Node.js中的错误处理 同步代码中…

【Node.js从基础到高级运用】十三、NodeJS中间件高级应用

在现代web开发中,Node.js因其高效和灵活性而备受青睐。其中,中间件的概念是构建高效Node.js应用的关键。在这篇博客文章中,我们将深入探讨Node.js中间件的高级应用,包括创建自定义中间件、使用第三方中间件等。我们将从基础讲起&a…

CTF题型 Http请求走私总结Burp靶场例题

CTF题型 Http请求走私总结&靶场例题 文章目录 CTF题型 Http请求走私总结&靶场例题HTTP请求走私HTTP请求走私漏洞原理分析为什么用前端服务器漏洞原理界定标准界定长度 重要!!!实验环境前提POST数据包结构必要结构快速判断Http请求走私类型时间延迟CL-TETE-CL 练习例题C…

三 C#插入排序算法

简介 插入排序算法是一种简单、直观的排序算法,其原理是将一个待排序的元素逐个地插入到已经排好序的部分中。 插入排序实现原理 插入排序算法是一种简单、直观的排序算法,其原理是将一个待排序的元素逐个地插入到已经排好序的部分中。 具体实现步骤…

Java类的初始化顺序

请直接看原文: Java类的初始化顺序_java创建顺序-CSDN博客 -------------------------------------------------------------------------------------------------------------------------------- 对于静态变量、静态初始化块、变量、初始化块、构造器,它们的…

滴答拍摄影项目|基于Spring Boot框架+ Mysql+Java+ Tomcat的滴答拍摄影项目设计与实现(可运行源码+数据库+设计文档)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 2024年56套包含java,ssm,springboot的平台设计与实现项目系统开发资源(可…

centos创建并运行一个redis容器 并支持数据持久化

步骤 : 创建redis容器命令 docker run --name mr -p 6379:6379 -d redis redis-server --appendonly yes 进入容器 : docker exec -it mr bash 链接redis : redis-cli 查看数据 : keys * 存入一个数据 : set num 666 获取数据 : get num 退出客户端 : exit 再退…

elk收集k8s微服务日志

一、前言 使用filebeat自动发现收集k8s的pod日志,这里分别收集前端的nginx日志,还有后端的服务java日志,所有格式都是用json格式,建议还是需要让开发人员去输出java的日志为json,logstash分割java日志为json格式&#…

java实现word转pdf

引入依赖包 <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>2.2.5.RELEASE</version></dependency><dependency><groupId…

jQuery+CSS3自动轮播焦点图特效源码

jQueryCSS3自动轮播焦点图特效源码&#xff0c;源码由HTMLCSSJS组成&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面 下载地址 jQueryCSS3自动轮播焦点图特效源码

day03vue学习

day03 一、今日目标 1.生命周期 生命周期介绍生命周期的四个阶段生命周期钩子声明周期案例 2.综合案例-小黑记账清单 列表渲染添加/删除饼图渲染 3.工程化开发入门 工程化开发和脚手架项目运行流程组件化组件注册 4.综合案例-小兔仙首页 拆分模块-局部注册结构样式完善…

LeetCode链表hard 有思路?但写不出来?

给你链表的头节点 head &#xff0c;每 k 个节点一组进行翻转&#xff0c;请你返回修改后的链表。 k 是一个正整数&#xff0c;它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍&#xff0c;那么请将最后剩余的节点保持原有顺序。 你不能只是单纯的改变节点内部的值…

功能齐全的免费 IDE Visual Studio 2022 社区版

面向学生、开放源代码和单个开发人员的功能齐全的免费 IDE 下载地址 Visual Studio 2022 社区版 - 下载最新的免费版本 Visual Studio 2022 Community Edition – Download Latest Free Version 准备安装 选择需要安装的程序 安装进行中 使用C学习程序设计相关知识并培养编程…

改变input placeholder的样式 (适用于vue uniapp 中的input textarea)

如下控制 <textarea name"" placeholder"请输入您要反馈的问题&#xff0c;以便我们为您解决" placeholder-style"font-weight: 500;font-size: 27rpx;color: #999999;" id"" cols"30" rows"10"></text…

电话机器人语音识别用哪家更好精准度更高。

语音识别系统的选择取决于你的具体需求&#xff0c;包括但不限于识别精度、速度、易用性、价格等因素。以下是一些在语音识别领域表现较好的公司和产品&#xff1a; 科大讯飞&#xff1a;科大讯飞是中国最大的语音识别技术提供商之一&#xff0c;其语音识别技术被广泛应用于各…

诺视科技完成亿元Pre-A2轮融资,加速Micro-LED微显示芯片商业化落地

近日&#xff0c;Micro-LED微显示芯片研发商诺视科技&#xff08;苏州&#xff09;有限公司&#xff08;以下简称“诺视科技”&#xff09;宣布完成亿元Pre-A2轮融资&#xff0c;本轮融资由力合资本领投&#xff0c;老股东盛景嘉成、汕韩基金以及九合创投持续加码&#xff0c;这…

Ubuntu 搭建gitlab服务器,及使用repo管理

一、GitLab安装与配置 GitLab 是一个用于仓库管理系统的开源项目&#xff0c;使用Git作为代码管理工具&#xff0c;并在此基础上搭建起来的Web服务。 1、安装Ubuntu系统&#xff08;这个教程很多&#xff0c;就不展开了&#xff09;。 2、安装gitlab社区版本&#xff0c;有需…