首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 整体架构与 SQL 执行原理,数据库事务原理

为了便于解决这些问题,需要引入数据库事务的概念。 定义 数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。...隔离性(Isolation):多个事务并发执行时,一个事务的执行不应影响其他事务的执行。 持久性(Durability):已被提交的事务对数据库的修改应该永久保存在数据库中。...锁 InnoDB存在两种锁 共享锁(S锁) :(插入/修改/删除)资源获取S锁之后,能加S锁,不能加X锁 排它锁(X锁) : 资源加上X锁之后,不能加S锁,也不能加X锁 数据库事务实现原理剖析 事务的实现原理...1、是正确执行完事务,没有出现任何问题;2、是事务提交成功但是出异常,数据库恢复之后,提交完成的事务会保证数据库完成该事物的操作。...然后进行数据的修改。如果出现了错误或者用户执行了ROLLBACK语句,系统可以利用Undo Log中的备份将数据恢复到事务开始之前的状态。

2.6K40

MySQL数据库——事务

概述 用户定义了一系列执行SQL语句的操作,这些操作要么完全的执行,要么全部都不执行,他是一个不可分割的工作执行单位,这也是为了保证数据库的完整性。...MySQL 事务主要用于处理操作量大,复杂度高的数据。 特征 原子性(Atomicity) 一事务是最小的执行单元,要么全部完成,要么全部不完成,不会结束在中间某个环节。...事务在执行过程中发生错误,会被回滚,回滚到没有执行前的状态。 一致性(Consistency) 从一个一致状态切换到另一个一致状态。在事务开始之前和事务结束以后,数据库的完整性没有被破坏。...隔离性(Isolation) 对其他事务不可见。数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。...持久性(Durability) 一旦提交事务,将被永久保存到数据库。事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。

29.8K75
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql设置隔离级别_修改mysql事务隔离级别

    Mysql默认的事务隔离级别是可重复读(Repeatable Read),那互联网项目中Mysql也是用默认隔离级别,不做修改么?...这里不想去搬binlog的概念了,就简单理解为binlog是一个记录数据库更改的文件吧~ binlog有几种格式?...OK,三种,分别是 statement:记录的是修改SQL语句 row:记录的是每行实际数据的变更 mixed:statement和row模式的混合 那Mysql在5.0这个版本以前,binlog只支持...(2)将binglog的格式修改为row格式,此时是基于行的复制,自然就不会出现sql执行顺序不一样的问题!奈何这个格式在mysql5.1版本开始才引入。...(笔者从未用过mysql自带的这个功能,因为这是XA事务,是强一致性事务,性能不佳!互联网的分布式方案,多采用最终一致性的事务解决方案!)

    2.7K10

    MySQL innodb引擎的事务执行过程

    如果在执行的过程中发生了错误,要回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过。...事务的持久性(Durability):事务一旦完成,该事务对数据库所做的所有修改都会持久的保存到数据库中。为了保证持久性,数据库系统会将修改后的数据完全的记录到持久的存储上。...二:redo和undo保证MySQL innodb事务的原子性和持久性: 总起来概述可以认为: undo用来保存数据更改之前的数据;保证原子性 redo用来保存数据更改之后的数据(注意是物理的修改信息)...如果出现了错误或者用户执行了ROLLBACK语句,系统可以利用Undo Log中的备份将数据恢复到事务开始之前的状态。...到底层文件,以 binlog 的写入与否作为事务提交成功与否的标志,最后判断 binlog中是否有 redo里的xid,MySQL5.6以前,为了保证数据库上层二进制日志的写入顺序和InnoDB层的事务提交顺序一致

    85111

    MySQL数据库进阶-事务

    ​系列专栏:MySQL数据库进阶 事务 事务由单独单元的一个或多个SQL语句组成,在这 个单元中,每个MySQL语句是相互依赖的。...而整个单独单 元作为一个不可分割的整体,如果单元中某条SQL语句一 旦执行失败或产生错误,整个单元将会回滚。...所有受到影 响的数据将返回到事物开始以前的状态;如果单元中的所 有SQL语句均执行成功,则事物被顺利执行。 1、概念:在mysql中的数据用各种不同的技术存储 在文件(或内存)中。...数据库事务的隔离性: 数据库系统必须具有隔离并发运行各个事务的能力, 使它们不会相互影响, 避免各种并发问题. 一个事务与其他事务隔离的程度称为隔离级别....Mysql 默认的事务隔离级别 为: REPEATABLE READ 在 MySql 中设置隔离级别 每启动一个 mysql 程序, 就会获得一个单独的数据库连接.

    11420

    MySQL事务的性情很“原子“,要么执行要么不执行

    丢失修改:一个事务修改了某个数据,另一个事务与其读取同一数据且原始值都相同,另一个事务修改数据后提交,导致第一个事务的修改操作丢失。 2.1 处理幻读问题 面试官:那幻读要怎么解决?...可以采用我提到的SERIALIZABLE(可串行化)隔离级别来解决幻读,事务按顺序执行,也就不会有幻读问题。 MySQL也提供了其他方法来处理幻读问题。...是这样的,死锁是因为多个事务互相占用对方请求的资源导致的现象,要打破这个问题需要回滚其中一个事务,这样另一个事务就能获得请求资源了,而回滚的事务只需要重新执行即可。...InnoDB引擎目前处理死锁的方法是通过持有行级排他锁的数量来判断,持有最少行级排他锁的事务会进行回滚。 2.4 隔离级别相关命令 面试官:有去看看你们数据库用的什么隔离级别吗?...有的,MySQL默认隔离级别是可重复读,企业生产一般也是用的这个隔离级别。

    225108

    查看Mysql正在执行的事务、锁、等待

    一、关于锁的三张表(MEMORY引擎) ## 当前运行的所有事务 mysql> select * from information_schema.innodb_trx\G; **************...SHOW WARNINGS命令:可以查看MySQL优化器优化后的SQL语句。     EXPLAIN PARTITIONS命令:显示SQL语句的带有分区表信息的查询执行计划。     ...MySQL会递归执行这些子查询, 把结果放在临时表里。 UNCACHEABLE SUBQUERY,结果集不能被缓存的子查询,必须重新为外层查询的每一行进行评估。...rows:显示MYSQL执行查询的行数,简单且重要,数值越大越不好,说明没有用好索引 Extra:该列包含MySQL解决查询的详细信息。...# 查看数据库默认存储引擎 mysql> show engines; +--------------------+---------+--------------------------------

    17.4K22

    mysql:Windows修改MySQL数据库密码(修改或忘记密码)

    今天练习远程访问数据库时,为了方便访问,就想着把数据库密码改为统一的,以后我们也会经常遇到MySQL需要修改密码的情况,比如密码太简单、忘记密码等等。...在这里我就借鉴其他人的方法总结几种修改MySQL密码的方法。...我就以实际操作修改root密码为例,操作系统为windows 这里我们需要注意的是,修改MySQL是需要MySQL中的root权限,一般用户是无法更改的,除非请求管理员。...用mysqladmin修改密码 1.打开cmd进入MySQL的bin目录;(如我的路径是F:\MySQL\mysql-5.7.24-winx64\bin) 2.修改MySQL的root用户密码格式:mysqladmin...3.再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),输入mysql回车,如果成功,将出现MySQL提示符 >。 连接权限数据库: use mysql; 。

    15.9K20

    数据库事务系列-MySQL跨行事务模型

    说来和MySQL倒是有缘,毕业的第一份工作就被分配到了RDS团队,主要负责把MySQL弄到云上做成数据库服务。...使用undo实现原子性在操作任何数据之前,首先会将修改前的数据记录到undo log中,再进行实际修改。如果出现异常需要回滚,系统可以利用undo中的备份将数据恢复到事务开始之前的状态。...现在假设有一个事务trx2修改了该行数据,该行记录就会变为下图形式,DB_TRX_ID为最近修改该行事务的事务ID(trx2),DB_ROLL_PTR指向undo历史纪录链表: 了解了MySQL行记录之后...如下图所示,1号事务对针对id>1的过滤条件执行了三次查询,2号事务执行了一次插入,插入的记录刚好符合id>1这个条件。...为N则表示每写N次操作系统缓冲就执行一次刷新操作。 总结一下,本文是数据库事务系列文章的第三篇,核心介绍了MySQL的单机跨行事务模型,其中对隔离性所涉及到的锁技术、MVCC机制进行了比较详细的说明。

    1.2K10

    数据库事务系列-MySQL跨行事务模型

    说来和MySQL倒是有缘,毕业的第一份工作就被分配到了RDS团队,主要负责把MySQL弄到云上做成数据库服务。...使用undo实现原子性在操作任何数据之前,首先会将修改前的数据记录到undo log中,再进行实际修改。如果出现异常需要回滚,系统可以利用undo中的备份将数据恢复到事务开始之前的状态。...现在假设有一个事务trx2修改了该行数据,该行记录就会变为下图形式,DB_TRX_ID为最近修改该行事务的事务ID(trx2),DB_ROLL_PTR指向undo历史纪录链表: ?...如下图所示,1号事务对针对id>1的过滤条件执行了三次查询,2号事务执行了一次插入,插入的记录刚好符合id>1这个条件。...为N则表示每写N次操作系统缓冲就执行一次刷新操作。 总结一下,本文是数据库事务系列文章的第三篇,核心介绍了MySQL的单机跨行事务模型,其中对隔离性所涉及到的锁技术、MVCC机制进行了比较详细的说明。

    1.5K20

    数据库-数据库-MySQL(12)- 事务

    举个例字就像张三向李四转账1000,但是完成这个操作,首先查看张三的余额有没有1000元,然后让张三的余额减少1000元,李四的余额加上1000元,  默认MySQL的事务是默认提交的,也就是说,当执行一条...DML语句,MySQL会立即隐式的提交事务。...COMMIT; commit 命令用来将事务中的修改保到数据库中,同时结束事务。 ...回滚事务  ROLLBACK; rollback 命令用来将数据库恢复到事务开始前的状态,即撤销事务所做的一切修改并结束事务  首先初始的时候  SELECT @@autocommit; 可以的到的是...优秀的数据库软件要确保每个事务都有ACID特性,并且具有很好的恢复特性,可以在机器有各种原因崩溃时恢复数据库 ---- 并发事务问题  脏读   开始时,事务A,执行select操作,然后执行update

    1.8K30

    MySQL数据库事务隔离级别

    数据库隔离级别有四种,应用《高性能mysql》一书中的说明: 然后说说修改事务隔离级别的方法: 1.全局修改,修改mysql.ini配置文件,在最后加上 1 #可选参数有:READ-UNCOMMITTED...本来默认也是这个级别 2.对当前session修改,在登录mysql客户端后,执行命令: 要记住mysql有一个autocommit参数,默认是on,他的作用是每一条单独的查询都是一个事务,并且自动开始...,加锁后其他用户只能获取该表或行的共享锁,不能获取排它锁,也就是说只能读不能写 排它锁: 由写表操作加上的锁,加锁后其他用户不能获取该表或行的任何锁,典型是mysql事务中 start transaction...; select * from user where userId = 1 for update; 执行完这句以后   1)当其他事务想要获取共享锁,比如事务隔离级别为SERIALIZABLE的事务,执行...select * from user;   将会被挂起,因为SERIALIZABLE的select语句需要获取共享锁   2)当其他事务执行 select * from user where userId

    2.4K71

    【MySQL】:数据库事务管理

    前言 事务是数据库管理系统中非常重要的概念,它保证了数据库操作的一致性和完整性。在实际应用中,我们经常需要处理复杂的数据操作,而事务的特性和隔离级别对数据库操作的并发性和稳定性有着重要影响。...为了解决上述的问题,就需要通过数据的事务来完成,我们只需要在业务逻辑执行之前开启事务,执行完毕后提交事务。如果执行过程中报错,则回滚事务,把数据恢复到事务开始之前的状态。...注意: 默认MySQL的事务是自动提交的,也就是说,当执行完一条DML语句时,MySQL会立即隐式的提交事务。 二....上述的这种方式,我们是修改了事务的自动提交行为, 把默认的自动提交修改为了手动提交, 此时我们执行的 DML语句都不会提交, 需要手动的执行commit进行提交。...事务隔离级别 为了解决并发事务所引发的问题,在数据库中引入了事务隔离级别。

    25910

    MySQL性能瓶颈分析-大事务执行计划

    一、大事务查询1.1 当前运行的所有事务select * from information_schema.innodb_trx\G1.2 锁等待的对应关系select * from information_schema.innodb_lock_waits...使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。...官网介绍:https://dev.mysql.com/doc/refman/5.5/en/explain-output.html2.2 执行计划能干嘛?...语法:       Explain+SQL语句案例:mysql> select * from tbl_emp;mysql> explain select * from tbl_emp;执行计划包含的信息...:文章推荐:MySQL Explain执行计划输出字段解读三、MySQL常见性能问题3.1 业务侧问题(1)缺少主键(2)缺少索引(3)SQL写的烂3. 2 MySQL宿主瓶颈(1)CPU:CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候

    9310

    MySQL执行大事务会存在什么问题?

    实现百万级数据从Excel导入的文章: 实现百万级数据从Excel导入到数据库的方式 所谓大事务,通常指包含大量要执行的SQL语句和较长执行时间的事务。 这样的大事务往往会带来诸多问题。...如下: 占用数据库连接:这一点很好理解。随着SQL语句的增多,执行时间也会相应延长。...大型事务会持续占用数据库连接,由于数据库连接资源有限,长时间占用可能导致其他事务无法获取连接,从而降低系统的吞吐量,影响系统的可用性。 难以回滚:大事务涉及的数据量较大,回滚操作可能变得异常耗时。...若事务需要回滚或失败,可能需要花费大量时间才能完全撤销所有修改,对数据库的可靠性和性能造成不利影响。 锁竞争:大事务可能引发繁琐的写操作,导致数据的锁定。...将不需要在事务中执行的操作(如读取、内存计算、I/O操作、远程调用等)移到事务外部处理。 好了,本章节到此告一段落。希望对你有所帮助,祝学习顺利。

    19210

    Mysql-事务执行过程(两阶段提交)

    如果不使用"两阶段提交",那么数据库的状态就有可能和用它的日志恢复出来的库的状态不一致:一、先写 redolog 后写 binlog 会丢失数据 1、先写 redolog 后写 binlog。...假设在 redolog 写完,binlog 还没有写完的时候, MySQL 进程异常重启,这时候 binlog 里面就没有记录这个语句。...然后告知执行器执行完成了,随时可以提交事务。2、执行器生成这个操作的 binlog,并把 binlog 写入磁盘。...1、binlog(归档日志):将执行完的增删改SQL语句的具体操作记录到binlog中,MySQL 自带的日志模块2、undo_log(回滚日志):支持事务原子性,数据更改前的快照,可以用来回滚数据(记录旧数据...)3、redo_log(更新、重做日志):支持事务持久性,记录修改操作的日志,用来崩溃后的数据恢复(记录新数据), InnoDB 引擎自带了日志模块。

    59311
    领券