MySQL数据库事务原理及应用
今天golang学习网给大家带来了《MySQL数据库事务原理及应用》,其中涉及到的知识点包括事务、MySQL数据库等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~
1 事务的使用
1.1 事务概念
事务就是一组DML语句组成,这些语句在逻辑上存在相关性,这一组DML语句要么全部成功,要么全部失败,是一个整体。MySQL提供一种机制,保证我们达到这样的效果。事务还规定不同的客户端看到的数据是不相同的。
事务就是要做的或所做的事情,主要用于处理操作量大,复杂度高的数据。假设一种场景:你毕业了,学校的教务系统后台 MySQL 中,不在需要你的数据,要删除你的所有信息(一般不会:) ), 那么要删除你的基本信息(姓名,电话,籍贯等)的同时,也删除和你有关的其他信息,比如:你的各科成绩,你在校表现,甚至你在论坛发过的文章等。这样,就需要多条 MySQL 语句构成,那么所有这些操作合起来,就构成了一个事务。
正如我们上面所说,一个 MySQL 数据库,可不止你一个事务在运行,同一时刻,甚至有大量的请求被包装成事务,在向 MySQL 服务器发起事务处理请求。而每条事务至少一条 SQL ,最多很多 SQL ,这样如果大家都访问同样的表数据,在不加保护的情况,就绝对会出现问题。甚至,因为事务由多条 SQL 构成,那么,也会存在执行到一半出错或者不想再执行的情况,那么已经执行的怎么办呢?
所以,一个完整的事务,绝对不是简单的 sql 集合,还需要满足如下四个属性:
- 原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
- 一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。
- 隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交( Read uncommitted )、读提交( read committed )、可重复读( repeatable read )和串行化( Serializable )
- 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失
1.2 事务的提交
事务的提交方式常见的有两种:
- 自动提交
- 手动提交
查看事务提交方式
mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.41 sec)
用 SET 来改变 MySQL 的自动提交模式
mysql> SET AUTOCOMMIT=0; #SET AUTOCOMMIT=0 禁止自动提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | OFF | +---------------+-------+ 1 row in set (0.00 sec) mysql> SET AUTOCOMMIT=1; #SET AUTOCOMMIT=1 开启自动提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.01 sec)
1.3 事务的常见操作
开启事务:start transaction;
执行多条SQL语句
回滚或提交:rollback/commit;
说明:rollback即是全部失败,commit即是全部成功
2 事务隔离
2.1 事务并发时出现的问题
脏读(第一个事务修改数据但没有提交,第二个事务就读取,在第一个事务回滚后,第二个事务读取的就是脏数据)
不可重复读(一个事务两次读取数据,中间有另一个事务修改,第一个事务两次读取的数据就不同)
幻读 一个事务两次读取,中间有另一个事务执行了插入操作,造成第一个事务看到不同的结果
2.2 事务隔离级别
读未提交(Read Uncommitted): 在该隔离级别,所有的事务都可以看到其他事务没有提交的执行结果。(实际生产中不可能使用这种隔离级别的),但是相当于没有任何隔离性,也会有很多并发问题,如脏读,幻读,不可重复读等,我们上面为了做实验方便,用的就是这个隔离性。
读提交(Read Committed) :该隔离级别是大多数数据库的默认的隔离级别(不是 MySQL 默认的)。它满足了隔离的简单定义:一个事务只能看到其他的已经提交的事务所做的改变。这种隔离级别会引起不可重复读,即一个事务执行时,如果多次 select, 可能得到不同的结果。
可重复读(Repeatable Read): 这是 MySQL 默认的隔离级别,它确保同一个事务,在执行中,多次读取操作数据时,会看到同样的数据行。但是会有幻读问题。
串行化(Serializable): 这是事务的最高隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决了幻读的问题。它在每个读的数据行上面加上共享锁。但是可能会导致超时和锁竞争(这种隔离级别太极端,实际生产基本不使用)
隔离级别 | 脏读 | 不可重复读 | 幻读 |
---|---|---|---|
读未提交 | × | × | × |
读提交 | √ | × | × |
可重复读 | √ | √ | × |
串行化 | √ | √ | √ |
今天关于《MySQL数据库事务原理及应用》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

- 上一篇
- 浅谈一下MyISAM和InnoDB存储引擎的区别

- 下一篇
- 一文详解MySQL Join使用原理
-
- 畅快的毛巾
- 这篇文章出现的刚刚好,太细致了,很棒,已加入收藏夹了,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-05-15 02:54:33
-
- 糊涂的飞鸟
- 这篇博文太及时了,细节满满,很有用,已加入收藏夹了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-05-15 00:10:44
-
- 个性的电源
- 这篇文章太及时了,太全面了,很棒,码住,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-05-13 18:47:49
-
- 老实的黄蜂
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢老哥分享博文!
- 2023-05-13 18:42:00
-
- 数据库 · MySQL | 15小时前 |
- MySQL数据库30条必学命令详解
- 280浏览 收藏
-
- 数据库 · MySQL | 18小时前 |
- MySQL安装配置教程手把手教学步骤
- 197浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL增删改查全攻略详解
- 412浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL分片方案与实现方法解析
- 318浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL安装配置教程手把手教你安装步骤
- 486浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL基础命令速查新手必学指南
- 129浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL数据库入门:核心概念与操作全解析
- 315浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- 主键外键关系解析与关联原理
- 157浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL常用存储引擎有哪些?InnoDB与MyISAM对比解析
- 174浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL创建数据库的详细步骤教程
- 283浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQLLIKE查询优化技巧分享
- 302浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据库30条必备管理命令
- 143浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 129次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 124次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 137次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 134次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 135次使用
-
- MySQL事务处理特性的实现原理
- 2023-01-20 138浏览
-
- Go GORM 事务详细介绍
- 2023-01-07 187浏览
-
- golang gorm错误处理事务以及日志用法示例
- 2023-02-16 412浏览
-
- Spring中的@Transactional注解
- 2023-01-24 448浏览
-
- golang db事务的统一封装的实现
- 2023-01-07 114浏览