MySQL基础篇 - 事务

01 事务的简介

【1】什么是事务:事务是一组操作集合,要么同时操作成功,要么同时操作失败。

【2】对于MySQL数据库来说默认一条SQL语句就是一个事务,且事务是默认自动提交的。

         我们可以把多条SQL语句设置成一个事务,使得要么同时操作成功,要么同时操作失败。

         具体的流程是,我们在使用这个事务时要手动开启事务,如果事务中的语句全部正常执行,则手动提交事务,如果在执行过程中出现异常,那么手动让事务回滚。

02 事务操作

【方式一】:通过autocommit修改所有事务的提交方式

【1】查看/设置事务的提交方式:

   ① select @@autocommit;// 查看事务的自动提交方式,注意这里只针对当前会话

   ② set @@sutocommit = 0;// 设置事务提交方式:1为自动提交,0为手动提交

【2】提交事务:commit;

【3】回滚事务:rollback;

【方式二】:通过手动开启事务语句控制某一段语句的构成的事务

【1】手动开启事务:start transaction; 或 begin;

【2】提交事务:commit;

【3】回滚事务:rollback;

【注意】:只有提交事务后,结果才会改变!!!

03 事务四大特性

【1】原子性:事务是不可分割的最小操作单元,要么全部操作成功,要么全部操作失败。

【2】一致性:事务完成时,必须使所有的数据都保持一致的状态。

【3】隔离性:数据库系统提供了隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。

【4】持久性:事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

04 并发事务问题

【1】并发事务引发的问题:A事务和B事务 ... 在同时操作同一个数据库/表时所引发的问题

【2】分类:

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

   ② 不可重复读:一个事务两次读取相同的东西时,读取出来的结果不同。

   ③ 幻读:一个事务按照条件查询数据时,没有查到对应的数据行,但是在执行插入数据时,又发现这行数据已经存在了,然后再查的时候发现又没有对应的数据行。

05 事务隔离级别

单词说明:transation交易,isolation隔离,session会议,serializable可串行化的

【1】事务隔离级别:用于解决并发事务所引发的三种问题。

【2】分类:

【3】查看事务的隔离级别:select @@transaction_isolation;

         补充:当前安装版本:查看当前会话的隔离级别,select @@session.tx_isolation;

                                             查看全局会话的隔离级别,select @@global.tx_isolation;

【4】修改事务的隔离级别:set session/global transation isolation level xxxx; 

         session代表只针对当前客户端窗口有效,global代表针对所有客户端的窗口有效。

【5】注意:

   ① 事务的隔离级别越高,数据越安全,但性能越低。

   ② serializable其实本质是:将并发的事务一个一个处理,所以它的性能最低。

   ③ 一般我们会使用数据库的默认隔离级别,不会去主动修改。

【6】说明:

   ① read uncommitted,例如:事务A修改了数据,但没有提交事务,此时事务B使用到的数据是事务A修改后的结果。

   ② read committed,例如:事务A修改了数据,但没有提交事务,此时事务B使用到的数据仍然是未修改前的,只有事务A提交事务了,事务B才会使用到修改后的数据。

   ③ repeatable read,例如:事务A修改了数据,并且提交了事务,事务B中使用的仍然会是原来的数据。

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

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

相关文章

java:pdfbox 删除扫描版PDF中文本水印

官网下载 https://pdfbox.apache.org/download.html下载 pdfbox-app-3.0.3.jar cd D:\pdfbox 运行 java -jar pdfbox-app-3.0.3.jar java -jar pdfbox-app-3.0.3.jar Usage: pdfbox [COMMAND] [OPTIONS] Commands:debug Analyzes and inspects the internal structu…

Spring Boot技术栈:打造高效在线商城

2 相关技术 2.1 Springboot框架介绍 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring…

重学SpringBoot3-集成Redis(一)

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(一) 1. 项目初始化2. 配置 Redis3. 配置 Redis 序列化4. 操作 Redis 工具类5. 编写 REST 控制器6. 测试 API7. 总结 随…

vSAN01:vSAN简介、安装、磁盘组、内部架构与调用关系

目录 传统的共享存储vSAN存储OSA的系统要求vSAN安装vSAN集群vSAN skyline healthvSAN与HA磁盘组混合磁盘架构全闪磁盘架构 vSAN对象vSAN内部架构 传统的共享存储 通过隔离的存储网络使得不同的ESXi主机访问独立的存储设备。需要前期投入较高的资金单独采购存储、网络可以单独规…

【Windows】自定义显示器的分辨率

背景 由于本人更新驱动导致2个显示器里面,有一个显示器的分辨率只剩下2个可以调节 这样就导致2个显示器分辨率不同,更新了多次驱动都修复不了,所以想着看能不能自定义分辨率 工具下载 显示器自定义分辨率工具 或者百度搜索 Custom Resolu…

STM32GPIO输入和输出

目录 一、先看IO端口位的结构 1、I/O输入: 2、I/O输出: 二、GPIO模式 三、枚举类型 四、GPIO输出点亮LED 五、LED流水灯 六、让蜂鸣器响起来 七、光敏传感器控制蜂鸣器 一、先看IO端口位的结构 上面部分是输入,下面是输出。 1、I/O输…

JAVA基础语法 Day11

一、Set集合 Set特点:无序(添加数据的顺序和获取出的数据顺序不一致),不重复,无索引 public class demo1 {public static void main(String[] args) {//1.创建一个集合//HashSet特点:无序,不重…

【操作系统】体系结构

🌹😊🌹博客主页:【Hello_shuoCSDN博客】 ✨操作系统详见 【操作系统专项】 ✨C语言知识详见:【C语言专项】 目录 操作系统的内核 操作系统结构——分层结构 操作系统结构——模块化 操作系统结构——宏内核、微内核…

Unity各个操作功能+基本游戏物体创建与编辑+Unity场景概念及文件导入导出

各个操作功能 部分功能 几种操作游戏物体的方式: Center:有游戏物体父子关系的时候,中心点位置 Global/Local:世界坐标系方向/自身坐标系方向 :调试/暂停/下一帧 快捷键 1.Alt鼠标左键:可以实现巡游角度查看场景 2.鼠标滚轮…

Linux忘记root用户密码怎么重设密码

直接说步骤: 1.重启客户机 2.在选择内核页面快速按e键,进入编辑模式 进入后应该是这个样子 在这里只能按上下键切换行 找到Linux16这里 3.按右方向键切换到行尾,也就是UTF-8处,在后面添加一个空格,然后加上这段话 …

【回眸】Tessy 单元测试软件使用指南(四)常见报错及解决方案与批量初始化的经验

前言 分析时Tessy的报错 1.fatal error: Tricore/Compilers/Compilers.h: No such file or directory 2.error: #error "Compiler unsupported" 3.warning: invalid suffix on literal;C11 requires a space between literal and string macro 4.error: unknown…

C0004.Qt中QComboBox设置下拉列表样式后,下拉列表样式无效的解决办法

问题描述 我们平时在使用Qt Creator对控件QComboBox的样式进行设置后,在运行程序启动界面时,发现设置的样式无效,效果如下: /* 设置下拉菜单框的样式 */ QComboBox QAbstractItemView {border: 1px solid rgb(161,161,161); /* …

【D3.js in Action 3 精译_028】3.4 小节 DIY 实战:使用 Observable 在线绘制 D3 条形图

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一部分 D3.js 基础知识 第一章 D3.js 简介(已完结) 1.1 何为 D3.js?1.2 D3 生态系统——入门须知1.3 数据可视化最佳实践(上)1.3 数据可…

leetcode135:分发糖果

步骤1:计算问题性质的定义 我们需要解决的题目是一个典型的贪心算法问题,要求分发糖果的数量,满足特定条件。以下是问题的详细定义: 输入: ratings:长度为 n 的数组,表示每个孩子的评分&#x…

【51单片机】点亮LED之经典流水灯

开发环境 开发板:普中51-单核-A2单片机:STC89C52RC(双列直插40引脚 DIP40)Keil uVision5 v9.61 最新版破解方法自行百度,相关文档和视频资料很多,我自己将这一操作记录下来当做博客发布,CSDN以…

Pikachu-Unsafe FileUpload-客户端check

上传图片,点击查看页面的源码, 可以看到页面的文件名校验是放在前端的;而且也没有发起网络请求; 所以,可以通过直接修改前端代码,删除 checkFileExt(this.value) 这部分; 又或者先把文件名改成…

职业技术学校开设无人机培训技术详解

职业技术学校开设无人机培训技术,是一个涉及多个方面的综合性教学过程。以下是对该培训技术的详细解析: 一、培训目标 无人机培训技术的目标在于培养学员掌握无人机的基本原理、组装调试、飞行操作、安全规范及维修保养等技能,使其成为具备…

【Android】中级控件

其他布局 相对布局RelativeLayout RelativeLayout下级视图的位置是相对位置,得有具体的参照物才能确定最终位置。如果不设定下级视图的参照物,那么下级视图默认显示在RelativeLayout内部的左上角。用于确定视图位置的参照物分两种,一种是与…

Linux环境基础开发工具使用(2)

个人主页:C忠实粉丝 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C忠实粉丝 原创 Linux环境基础开发工具使用(2) 收录于专栏[Linux学习] 本专栏旨在分享学习Linux的一点学习笔记,欢迎大家在评论区交流讨论💌 目录 1. Li…

Qt Quick 3D 入门:QML 3D场景详解

随着 Qt 6 的发布,QtQuick3D 模块带来了新的 3D 渲染和交互能力,使得在 Qt 中创建 3D 场景变得更加简单和直观。本文将带您从一个简单的 QML 3D 应用开始,详细讲解各个相关领域的概念、代码实现以及功能特点。 什么是 Qt Quick 3D&#xff1…