首页 > 数据库 >MySQL的事务(看看也许有帮助呢)

MySQL的事务(看看也许有帮助呢)

时间:2023-12-26 09:13:51浏览次数:35  
标签:帮助 事务 log 数据 提交 MySQL redo 隔离

MySQL的事务

一、事务的概念

在MySQL中,只有InnoDB存储引擎才支持事务。
事务的处理用来维护数据库数据的完整性,保证同一个事务里的一批SQL语句,要么全部执行,要么全部不执行。
事务用来管理DDL、DML、DCL操作,比如insert、update、delete语句,默认自动提交,即执行SQL语句后会马上执行commit操作。
显示地开启一个事务必须使用命令begin或者start transaction,或者执行命令set autocommit=0,用来禁止使用当前会话的自动提交。

  • BEGIN或START TRANSACTION:显示地开启一个事务。
  • COMMIT:提交事务,并使已数据库进行的所有修改是永久的。
  • ROLLBACK:回滚,结束用户的事务,并撤销正在进行的所有未提交的修改。

二、事务的并发问题

在事务的并发操作中可能会出现如下的问题:

  • 丢失更新:一个事务更新之后,另外一个事务也对这个数据进行了更新,那么第一个事务的更新就丢失了。
  • 脏读:一个事务读取到了另外一个事务未提交的数据
  • 不可重复读:一个事务因读取到另外一个事务已经提交的数据。导致对同一条记录的读取两次以上的结果不一致。update操作。
  • 幻读:一个事务因读取到另外一个事务已提交的数据,导致对同一张表的读取结果不一致,insert、delete所致。

三、事务的隔离级别

3.1 事务的隔离级别

为了避免以上几种情况的出现,在标准的SQL规范中,定义了4个事务隔离级别,不同隔离级别对事务的处理不同:
四种隔离级别由低到高分别为:

  • Read uncommitted(读未提交):最低隔离界别,任何情况都无法保障
  • Read committed(读已提交):可避免脏读发生
  • Repeated read(可重复读):可避免脏读和不可重复读的发生。Innodb的RR还可以解决幻读,主要原因是GAP锁(间隙锁),只有RR才能使用GAP锁。
  • serializable(串行化):可避免所有情况(MVCC降低为Locaking-Base CC)

3.2 默认隔离级别

大多数数据库的默认隔离级别是Read committed,比如Oracle和DB2等。MySQL数据库的默认隔离级别是Repeatable Read。
在MySQL数据库中查看当前事务的隔离级别:
select @@tx_isolation;
在MySQL中设置事务的隔离级别:

set [glogal|session]transaction isolation level 隔离级别名称;
或者
set tx_isolation='隔离级别名称';

隔离级别越高,越能保障数据的一致性和完整性,但是对并发性能的影响也越大。
对于多数的应用程序,可以把默认隔离级别设置为Read Committed,为避免脏读读取,同时还具有良好的并发性能。在可能出现不可重复读、幻读这些问题的场合,可以由应用程序采用悲观
锁或者乐观锁来控制。

3.3 Mysql的事务流程

以update为例,innodb的事务流程如下:

update upms_user set real_name='测试'where user_name='A001';

1)事务开始
2)对user_name='A001'这条数据上排他锁,并对数据两边临近范围加gap锁,防止别的事务insert新数据,保证隔离性。
3)将需要修改的数据页加载到innodb_buffer_cache中(内存中的一块区域)。
4)记录检索数据到undo log(修改前的数据,用来保证数据的原子性和一致性)。
5)修改user_name='A001'的数据real_name='测试'。记录修改数据信息到redo log(注意,是数据的当前页修改操作信息,而不是修改后的数据,用来保证持久性),redo log处于prepare状态,随时可以提交事务。
6)刷新innodb_buffer_cache中脏数据到底层磁盘,非commit触发,数据库自动操作。
7)记录binlog,写入磁盘。
8)提交事务,把刚才的redo log改提交状态(两阶段提交)
9)事务结束

四、事务日志文件

4.1 undo log

undo用来保存数据更改之前的数据;保证原子性、一致性。InnoDB存储引擎中,还用Undo log来实现多版本并发控制(MVCC)。
undo log的目的就是满足事务的原子性。操作任何数据之前,首先将数据备份到undo log,然后进行数据的修改。
undo log是为了解决回滚问题,如果出现了错误或者用户执行了ROLLBACK语句,系统可以利用undo log中的备份将数据恢复到事务开始之前的状态。

4.2 redo log

数据库先写redo logo,然后才修改buffer cache中的页(修改数据),修改是以页为单位的,所以先写redo才能保证一个大事务commit的时候,redo已经刷新的差不多了。反过来说假如是先改buffer cache中的页,然后再写redo,就可能会由很多redo需要写,因为一个页中可能有很多数据行,而很多数据行产生的redo也可能比较多,那么commit的时候,就可能会有很多redo需要写。
在事务提交前,只需要将redo log持久化即可。不需要将数据持久化,当系统崩溃时,虽然数据没有持久化,但是Redo log已经持久化。系统可以根据redo log的内容,将所有的数据恢复到最新的状态。需要注意的是,事务过程中,先把redo写进redo log buffer中,然后MySQL后台进程page cleaner thread适当的去刷新redo到底层磁盘永久保存。

标签:帮助,事务,log,数据,提交,MySQL,redo,隔离
From: https://www.cnblogs.com/JavaBuild/p/17927343.html

相关文章

  • MySql之json_extract函数处理json字段
    转自:链接:https://juejin.cn/post/7103482347894358046 MySql之json_extract函数处理json字段在db中存储json格式的数据,相信大家都或多或少的使用过,那么在查询这个json结构中的数据时,有什么好的方法么?取出String之后再代码中进行解析?接下来本文将介绍一下Mysql5.7+之后提供的......
  • 2数据库之Mysql基本操作
                                                                                                      数据库基本类型、基本操作一.......
  • MySQL-索引数据结构
    BTreeB-树即B树。指的是BalanceTree,也就是平衡树,平衡树是一颗查找树,并且所有叶子节点位于同一层。每个结点存储M/2到M个关键字,非叶子结点存储指向关键字范围的子结点。所有关键字在整颗树中出现,且只出现一次,非叶子结点可以命中。B+Tree是B树的一种变形,它是基于B......
  • MySQL索引-索引结构
    索引是什么索引是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查询算法,这种数据结构就是索引。优缺点:优点:提高数据检索效率,降低数据库的IO成本通......
  • mysql主从同步原理
    (1)master服务器将数据的改变记录二进制binlog日志,当master上的数据发生改变时,则将其改变写入二进制日志中(2)slave服务器会在一定时间间隔内对master二进制日志进行探测其是否发生改变,如果发生改变,则开始一个IOThread请求master二进制事件(3)同时主节点大每个O线程启动一个du......
  • 数据库事务的作用
    数据库事务的主要作用是确保数据库在执行多个相关操作时能够保持一致性和完整性。事务是指一组数据库操作语句,这些语句将作为一个逻辑单元一起执行,要么全部执行成功,要么全部不执行。当一个事务成功提交后,数据库中的数据应该保持一致性状态,反之如果事务执行出错或中断,则要回滚事务,使......
  • 数据库 Mysql 多表查询,left join联合两个sql示例
    SELECTt1.RowID,t1.UserID,t1.CreateDate,t1.BatchState,t2.InputDataCount,t1.QtyFROM(SELECT@curRow:=@curRow+1ASRowID,`UserID`,DATE_FORMAT(CreateDate,'%Y-%m-%d')ASCreateDate,......
  • 数据库 MySql快速导入外部数据库流程
    适用于新安装MySql本地没有数据情况外部MySql数据库文件任务管理器停用Mysql进程将外部文件替换本地默认文件即可重启电脑导入完成。......
  • 保姆级搭建Mysql 并进行视图可视化操作
    安装MySQL数据库选择mysql5.7.36_x32.msi”,双击运行,如下图所示:在此窗口中,选择“Custom”选项,点击“Next>”进入下一步;在此窗口中,选择+号下的MySQLServer5.7.36–x64,点击中间的绿色箭头符号,添加完成如下图所示:然后点击“Next>”进入下一步进行安装;继续点击“Next>”进入下一步......
  • 美团面试:ES+Redis+MySQL高可用,如何实现?
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......