美文网首页
Mysql-事务

Mysql-事务

作者: 小橙子_43db | 来源:发表于2019-12-09 23:13 被阅读0次

MySQL 数据库中事务是用户一系列的数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。

为什么要使用事务

事务具有 4 个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)。这 4 个特性简称为 ACID 特性。

1) 原子性

事务必须是原子工作单元,事务中的操作要么全部执行,要么全都不执行,不能只完成部分操作。原子性在数据库系统中,由恢复机制来实现。

2) 一致性

事务开始之前,数据库处于一致性的状态;事务结束后,数据库必须仍处于一致性状态。数据库一致性的定义是由用户负责的。例如,在银行转账中,用户可以定义转账前后两个账户金额之和保持不变。

3) 隔离性

系统必须保证事务不受其他并发执行事务的影响,即当多个事务同时运行时,各事务之间相互隔离,不可互相干扰。事务查看数据时所处的状态,要么是另一个并发事务修改它之前的状态,要么是另一个并发事务修改它之后的状态,事务不会查看中间状态的数据。隔离性通过系统的并发控制机制实现。

4) 持久性

一个已完成的事务对数据所做的任何变动在系统中是永久有效的,即使该事务产生的修改不正确,错误也将一直保持。持久性通过恢复机制实现,发生故障时,可以通过日志等手段恢复数据库信息。

事务的 ACID 原则保证了一个事务或者成功提交,或者失败回滚,二者必居其一。因此,它对事务的修改具有可恢复性。即当事务失败时,它对数据的修改都会恢复到该事务执行前的状态。

开始事务

BEGIN TRANSACTION <事务名称> |@<事务变量名称>

提交事务

COMMIT TRANSACTION <事务名称> |@<事务变量名称>

撤销事务

ROLLBACK [TRANSACTION]

[<事务名称>| @<事务变量名称> | <存储点名称>| @ <含有存储点名称的变量名>

相关文章

  • 08 MySQL-初识MySQL-事务-隔离鉴别

    如果没有特别说明,都是默认autocommit=1 根据我的第三篇03 MySQL-初识MySQL-事务隔离级别提...

  • MySQL-事务

    ACID 测试 ACID 表示原子性、一致性、隔离性和持久性。一个运行良好的事务处理系统,必须具备这些标准概念。 ...

  • Mysql-事务

    事务特性ACID 原子性(Atomicity):事务作为一个整体被执行,包含在其中的对数据库的操作要么全部被执行,...

  • Mysql-事务

    MySQL 数据库中事务是用户一系列的数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。 为什...

  • Mysql-事务

    数据库事务4个特性 by shihang.mai 简称:ACID 特性解析原子性要么全部成功,要么全部失败一致性当...

  • mysql-事务

    http://baijiahao.baidu.com/s?id=1581064626251873652&wfr=s...

  • MYSQL-事务原理

    ACID模型 MYSQL传统关系数据库的ACID模型有以下特性 Atomicity原子性:一个事务中所有操作都必须...

  • # MySQL-事务介绍

    --- [TOC] --- # MySQL事务 ## ACID 1.**原子性(Atomcity)** 一个事务的...

  • MySQL-事务(Transaction)

    MySQL事务 特性(ACID): 原子性(automicity):要不全部成功,要不全部失败 一致性(consi...

  • MySQL-事务&MVCC

    前置文章:一、MySQL-存储引擎[https://www.jianshu.com/p/495108c767bc]...

网友评论

      本文标题:Mysql-事务

      本文链接:https://www.haomeiwen.com/subject/gcgigctx.html