MySQL基础篇 - 事务

news2024/12/24 9:42:35

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.coloradmin.cn/o/2186148.html

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

相关文章

pod管理及优化

一、k8s中的资源 1、资源介绍 [rootk8s-master ~]# kubectl --namespace timinglee get po No resources found in timinglee namespace. [rootk8s-master ~]# kubectl run testpod --image timinglee/nginx [rootk8s-master ~]# kubectl get pods -w NAME READY STATU…

AI大师工坊丨国庆节去哪玩?让旅游规划大师助你一臂之力

文章目录 零、写在前面一、旅游规划大师二、如何创造自己的智能体三、写在后面 零、写在前面 听说由百度文心智能体平台主办,万众瞩目的 AI大师工坊招募令 启动啦! 在本期大师工坊中,博主开发了一款超级实用的智能体:旅游规划大…

MySQL 启动失败 (code=exited, status=1/FAILURE) 异常解决方案

目录 前言1. 问题描述2. 查看错误日志文件2.1 确认日志文件路径2.2 查看日志文件内容 3. 定位问题3.1 问题分析 4. 解决问题4.1 注释掉错误配置4.2 重启 MySQL 服务 5. 总结结语 前言 在日常运维和开发过程中,MySQL数据库的稳定运行至关重要。然而,MySQ…

Framebuffer学习

目录 1. Framebuffer概念2. LCD操作原理3. 源码分析3.1 打开设备3.2 获取LCD参数3.3 映射Framebuffer3.4 描点实现 基于韦东山IMX6ULL开发板学习 参考教程: 韦东山老师教程 1. Framebuffer概念 Framebuffer,可以译作“帧缓冲”,有时简称为fb…

“衣依”服装销售平台:Spring Boot技术实践与创新

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常适…

【STM32开发笔记】移植AI框架TensorFlow到STM32单片机【下篇】

【STM32开发笔记】移植AI框架TensorFlow到STM32单片机【下篇】 一、上篇回顾二、项目准备2.1 准备模板项目2.2 支持计时功能2.3 配置UART4引脚2.4 支持printf重定向到UART42.5 支持printf输出浮点数2.6 支持printf不带\r的换行2.7 支持ccache编译缓存 三、TFLM集成3.1 添加tfli…

记录win11 蓝屏修复

1原因: win11 edge 的浏览器异常 打开新窗口的广告 打不开显示网络未连接下载驱动精灵 下载驱动要开会员 果断卸载 然后发现没有卸载干净 任务管理器 搜驱动 不小心干掉了win自带的文件win提示更新 更新重启就蓝屏随便点击一个新闻页面 解决办法: 在…

吴恩达深度学习笔记:卷积神经网络(Foundations of Convolutional Neural Networks)2.5-2.6

目录 第四门课 卷积神经网络(Convolutional Neural Networks)第二周 深度卷积网络:实例探究(Deep convolutional models: case studies)2.5 网络中的网络以及 11 卷积(Network in Network and 11 convoluti…

利用Spring Boot开发“衣依”服装销售系统

1系统概述 1.1 研究背景 如今互联网高速发展,网络遍布全球,通过互联网发布的消息能快而方便的传播到世界每个角落,并且互联网上能传播的信息也很广,比如文字、图片、声音、视频等。从而,这种种好处使得互联网成了信息传…

如何从 PC 中检索已删除的文件?从 PC 恢复已删除的照片技巧

按 Shift Delete 以后后悔?想要恢复已删除的照片吗?好吧,如果是这样的话,那么您来对地方了。在本文中,我们将讨论如何从 PC 中检索已删除的文件。 自从摄影的概念被提出以来,人们就对它着迷。早期的照片保…

YOLO11改进|上采样篇|引入DySample轻量级动态上采样器

目录 一、DySample轻量级动态上采样器1.1DySample上采样模块介绍1.2DySample核心代码 五、添加DySample上采样器5.1STEP15.2STEP25.3STEP35.4STEP4 六、yaml文件与运行6.1yaml文件6.2运行成功截图 一、DySample轻量级动态上采样器 1.1DySample上采样模块介绍 DySample是一种基…

Koa2+Vue2的简书后台管理系统

文章目录 项目实战:前(vue)后(koa)端分离1、创建简书项目2、创建数据库2.1 创建数据库2.2 连接数据库3、模型对象3.1 设计用户模块的Schema3.2 实现用户增删改查3.2.1 增加用户3.2.2 修改用户3.2.3 删除用户3.2.4 查询用户4、封装业务逻辑层5、封装CRUD6、创建Vue项目7、配…

“衣依”服装销售平台:Spring Boot技术架构剖析

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常适…

TCP四次挥手过程详解

TCP四次挥手全过程 有几点需要澄清: 1.首先,tcp四次挥手只有主动和被动方之分,没有客户端和服务端的概念 2.其次,发送报文段是tcp协议栈的行为,用户态调用close会陷入到内核态 3.再者,图中的情况前提是双…

【CKA】十、统计node节点ready状态的数量

10、统计node节点ready状态的数量 1. 考题内容: 2. 答题思路: 1、检查有多个node状态ready 2、去除有Taint和NoSchedule的节点数量 3、将结果写入到指定文件中 3. 官网地址: https://kubernetes.io/zh-cn/docs/reference/node/node-statu…

LeetCode[中等] 45. 跳跃游戏 II

给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] 处&#xff0c;你可以跳转到任意 nums[i j] 处: 0 < j < nums[i] i j < n 返回到达 nums[n - 1] 的最…

在Docker中运行微服务注册中心Eureka

1、Docker简介&#xff1a; 作为开发者&#xff0c;经常遇到一个头大的问题&#xff1a;“在我机器上能运行”。而将SpringCloud微服务运行在Docker容器中&#xff0c;避免了因环境差异带来的兼容性问题&#xff0c;能够有效的解决此类问题。 通过Docker&#xff0c;开发者可…

五子棋双人对战项目(4)——匹配模块(解读代码)

目录 一、约定前后端交互接口的参数 1、websocket连接路径 2、构造请求、响应对象 二、用户在线状态管理 三、房间管理 1、房间类&#xff1a; 2、房间管理器&#xff1a; 四、匹配器(Matcher) 1、玩家实力划分 2、加入匹配队列&#xff08;add&#xff09; 3、移除…

golang grpc初体验

grpc 是一个高性能、开源和通用的 RPC 框架&#xff0c;面向服务端和移动端&#xff0c;基于 HTTP/2 设计。目前支持c、java和go&#xff0c;分别是grpc、grpc-java、grpc-go&#xff0c;目前c版本支持c、c、node.js、ruby、python、objective-c、php和c#。grpc官网 grpc-go P…

Linux相关概念和重要知识点(11)(进程调度、Linux内核链表)

1.Linux调度算法 上篇文章我粗略讲过queue[140]的结构&#xff0c;根据哈希表&#xff0c;我们可以将40个不同优先级的进程借助哈希桶链入queue[140]中。调度器会根据queue的下标来进行调度。但这个具体的调度过程是怎样的呢&#xff1f;以及runqueue和queue[140]的关系是什么…