返回顶部
首页 > 资讯 > 数据库 >MySQL事务
  • 330
分享到

MySQL事务

MySQL事务 2022-01-22 01:01:59 330人浏览 才女
摘要

  一、事务的概念 事务就是一组原子性的sql查询,或者说一个独立的工作单元。如果数据库引擎能够成功地对数据库应用该组查询的全部语句,那么就执行该组查询。如果其中有任何一条语句因为崩溃或其他原因无法执行,那么所有的语句都不会执行。

MySQL事务

 

一、事务的概念

事务就是一组原子性的sql查询,或者说一个独立的工作单元。如果数据库引擎能够成功地对数据库应用该组查询的全部语句,那么就执行该组查询。如果其中有任何一条语句因为崩溃或其他原因无法执行,那么所有的语句都不会执行。也就是说,事务内的语句,要么全部执行成功,要么全部执行失败。

可以通过一个银行事例来解释事务的必要性。假设有以下场景:现在用户A想通过银行转账200元给用户B,那么至少需要三个步骤:

检查用户A的账户余额高于200元。

用户A账户减去200元。

用户B账户增加200元。

假设账户A扣钱后系统出现故障,则会出现账户A扣了钱,但账户B没收到钱的情况。为保证上诉三个步骤要么全部执行成功,要么全部执行失败,需打包在一个事务中,任何一个步骤失败,则回滚所有的步骤。

 

二、事务的ACID

ACID表示原子性(atomicity)、一致性(consistency)、隔离性(isolation)和持久性(durability)。一个良好的事务处理系统,必须具备这些标准特性。

原子性(atomicity):

一个事务必须被视为一个不可分割的最小工作单元,整个事务的所有操作要么全部执行成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作,这就是事务的原子性。

一致性(consistency):

数据库总是从一个一致性的状态转换到另一个一致性的状态。在前面的例子中,用了事务后,假设执行第三步的时候系统崩溃了,账户A不会损失200元,因为事务最终没有提交,所以事务中所做的修改也不会保存到数据库中。保持数据的一致性。

隔离性(isolation):

通常来说,一个事务所做的修改在最终提交以前,对其他事务是不可见的(这个和事务隔离级别有关)。在前面的例子中,当执行完第二步骤,第三步骤还没开始的时候,此时有另外一个程序开始运行,则看不到账户A的余额被扣除了200元。

持久性(durability):

一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,修改的数据也不会丢失。

 

三、事务的隔离级别

前面说到事务的隔离性其实和事务的隔离级别有关。在SQL标准中定义了四种隔离级别,每一种级别都规定了一个事务中所做的修改,哪些在事务内和事务间是可见的,哪些是不可见的。较低级别的隔离通常可以执行更高的并发,系统的开销也更低。

下面简单的介绍一下四种隔离级别。

未提交读(read uncommitted):

在未提交读级别,事务的修改,即使没有提交,对其他事务也都是可见的。事务可以读取未提交的数据,这也被称为脏读这个级别会导致很多问题,从性能上来说,未提交读不会比其他级别好太多,但却缺乏其他级别的很多好处,除非真的有非常必要的理由,在实际应用中一般很少使用。

举例:事务A读取到数据1,将数据改成2,即使事务A还没提交,事务B也能读取到数据2。

提交读(read committed):

大多数数据库系统的默认隔离级别都是提交读(但Mysql不是)。提交读满足前面提到的隔离性的简单定义:一个事务开始时,只能看见已经提交的事务所做的修改。换句话说,一个事务从开始直到提交之前,所做的任何修改对其他事务都是不可见的。这个级别有时候也叫做不可重复读,因为在同一个事务内两次执行相同的查询,可能会得到不一样的结果。

举例:事务B开启时读到数据1,接下来事务A开启,把这个数据改成2,提交,B再次读取这个数据,会读到最新的数据2。

可重复读(repeatable read):

可重复读解决了脏读的问题。该级别保证了在同一事务中多次读取同样记录的结果是一致的。

举例:事务B开启时读到数据1,接下来事务A开启,把这个数据改成2,提交,B再次读取这个数据,仍然读取到数据1。

但是理论上,可重复读隔离级别还是无法解决另一个幻读的问题。所谓幻读,指的是当某个事务在读取某个范围内的记录时,另一个事务又在该范围内插入了新的记录,当之前的事务再次读取该范围的记录时,会产生幻行,读取到新插入的数据。不过mysql中的InnoDB存储引擎通过多版本并发控制(mvcC)解决了幻读的问题。可重复读是MySQL的默认事务隔离级别。

可串行化(serializable):

可串行化是最高的隔离级别。它通过强制事务串行执行,避免了前面说的幻读的问题。简单来说,可串行化隔离级别会在读取的每一行数据上都加,所以可能导致大量的超时和锁争用的问题。实际应用中也很少用到这个隔离级别,只有在非常需要确保数据的一致性而且可以接受没有并发的情况下,才考虑采用该级别。

 

接下来用一个表格说明这四种隔离级别:

隔离级别 脏读可能性 不可重复读可能性 幻读可能性 加锁读
未提交读 Yes Yes Yes No
提交读 No Yes Yes No
可重复读 No No Yes No
可串行化 No No No Yes
您可能感兴趣的文档:

--结束END--

本文标题: MySQL事务

本文链接: https://lsjlt.com/news/5849.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL事务
      一、事务的概念 事务就是一组原子性的SQL查询,或者说一个独立的工作单元。如果数据库引擎能够成功地对数据库应用该组查询的全部语句,那么就执行该组查询。如果其中有任何一条语句因为崩溃或其他原因无法执行,那么所有的语句都不会执行。...
    99+
    2022-01-22
    MySQL事务
  • MySQL事务。
    相关资料:https://zhuanlan.zhihu.com/p/70701037        https://zhuanlan.zhihu.com/p/59061106 一、事务。   1、概念。事务是由一组SQL语句组成的逻辑处理单...
    99+
    2018-12-10
    MySQL事务。
  • MySQL——事务
    事务:指一组SQL语句 回滚:指撤销指定SQL语句的过程 提交:将未存储的SQL语句结果写入数据库表 保留点:事务处理过程中设置的临时占位符,可以对它发布回退 事务的四大特性 原子性:事务中所有的操作是不可...
    99+
    2018-05-27
    MySQL——事务
  • mysql-事务
    事务(transaction) 事务是业务逻辑的一个基本的单元组成。 每一个事务由一条条sql语句组成。 和事务相关的语句(insert,delete,update)这些DML语句 事务的存在保证了数据的安全性。 事务机制: 每...
    99+
    2019-08-05
    mysql-事务
  • MySQL 事务
    目录 什么是事务 为什么要使用事务 事务优点 总结事务命令 详细解释: 什么是事务 多条 sql 语句,要么全部成功,要么全部失败。 MySQL 的事务是在存储引擎层实现。 MySQL 的事务有 ACID ...
    99+
    2023-09-09
    mysql 数据库
  • MySQL—事务
    MySQL—事务 🔎定义🔎事务的特性原子性一致性持久性隔离性 🔎并发执行事务可能产生的问题脏读不可重复读幻读总结 🔎MySQL—事务的隔离级别 ǵ...
    99+
    2023-08-16
    mysql android 数据库
  • 【MySQL】事务
    文章目录 1. 前言2. 事务简介3. 事务操作4. 事务四大特性5. 并发事务的问题6. 事务隔离级别7. 总结 1. 前言 事务是数据库管理系统中非常重要的概念,本文主要介绍的是事务的四大特性,并发事务可能引发的问题以及事务...
    99+
    2023-08-17
    mysql 数据库 sql
  • mysql之事务
    我们先来说说什么是事务:       事务就是逻辑上的一组操作,组成这组操作的各个单元,要不全都成功,要不全都失败。一个事务是一个连续的...
    99+
    2024-04-02
  • MySQL InnoDB 事务
    事务的定义 事务:数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作; 事务是一组不可再分割的操作集合(工作逻辑单元)。 典型事务使用场景:转账 MySQL 开启事务: MySQL 默认是开启...
    99+
    2024-04-02
  • mysql与事务
    什么是事务 事务是作为一个逻辑单元执行的一系列操作,一个逻辑工作单元必须有四个属性,称为 ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务 一、事务的特性(ACID) ...
    99+
    2024-04-02
  • mysql基础(六)mysql事务
    mysql事务:是一个独立的工作单元 事务必须通过ACID测试:     原子性(Atomicity):一个事务的所有操作要么全部成功执行,要么全部失败后回滚 &n...
    99+
    2024-04-02
  • MySQL 事务管理
      事务的4个特性(ACID) 原子性 Atomicity。每个事务中的操作,要么都成功,要么都失败 一致性 Consistency。事务执行前后,数据库中的数据应该保持一致 隔离性 Isolation。事务之间应该是隔离的,事...
    99+
    2015-09-09
    MySQL 事务管理
  • MySQL事务介绍
    什么是事务 事务的概念 从业务层面上来说,事务就是一个最小的不可分割的单元,通常一个事务对应的是一个完整的业务(比如银行的转账操作)。 为什么要有事务 仍以银行转账为例加以说明,比如我要从账号A转账100元到账号B,现在数据库有一...
    99+
    2019-11-07
    MySQL事务介绍
  • MySQL事务处理
    概述 在MySQL中只有使用了InnoDB数据库存储引擎的数据库或表才支持事务。 事务处理可以用来维护数据库的完整性,保证成批的SQL语句要么全部成功,要么全部失败。 事务用来管理DDL、DML、DCL操作,比如:insert、...
    99+
    2014-12-03
    MySQL事务处理
  • Mysql事务原理
    一、什么是事务 事务:是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合(工作逻辑单元); 事务的四大特性: 原子性(Atom...
    99+
    2020-08-23
    Mysql事务原理
  • mysql事务详解
    事务的特性(Atomicity) 原子性 -- 回滚日志 一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这...
    99+
    2016-12-01
    mysql事务详解 数据库入门 数据库基础教程 数据库 mysql
  • MySQL事务学习
    MySQL事务: 1、事务特性:原子性,一致性,隔离性,持久性 原子性:对一些操作,要么同时成功,要么同时失败。 一致性:对一些操作,处理结果必须一致的,比如转账:A转给B,那么A账户减少100元,则B账户必须增加100元。 隔离性:多个...
    99+
    2019-11-20
    MySQL事务学习
  • MySQL 事务和锁
    事务概述 当多个用户访问同一份数据时,一个用户在更改数据的过程中,可能有其他用户同时发起更改请求,为保证数据库记录的更新从一个一致性状态变为另外一个一致性状态,使用事务处理是非常必要的,事务具有以下四个特性: 原子性(Atomicit...
    99+
    2020-12-06
    MySQL 事务和锁
  • MySQL 索引事务
    目录 1. 索引1.1 概念1.2 索引的使用1.2.1 查看索引1.2.2 创建索引1.2.3 删除索引1.2.4 索引背后的数据结果 2. 事务2.1 概念2.2 事务的特性2....
    99+
    2023-09-16
    mysql 数据库
  • mysql 事务解析
    事务(transaction) 事务是业务逻辑的一个基本的单元组成。 每一个事务由一条条sql语句组成。 和事务相关的语句(insert,delete,update)这些D...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作