美文网首页
Mysql事务控制

Mysql事务控制

作者: 周赫威 | 来源:发表于2020-02-17 09:39 被阅读0次

 事务主要用于处理操作量大,复杂度高的数据

举例说明1:在人员管理系统中,你删除一个人员,你既需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章。

举例说明2:在一个论坛系统中,添加一条评论,需要对评论个数进行+1,对文章用户的提醒+1。

事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)

原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。

一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。

隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。

持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。

       在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

SAVEPOINT identifier,SAVEPOINT 允许在事务中创建一个保存点,一个事务中可以有多个 SAVEPOINT;

1、未提交可读:A事务修改某条记录,未提交;B事务可以读取A事务修改后的该条记录数据值。

2、提交可读(不可重复读):A事务第一次读取某条记录后,B事务修改该条记录且提交,A事务再次读取该条记录,A事务2次读取的值不同。

3、可重复读:A事务第一次读取某条记录后,B事务修改该条记录且提交,A事务再次读取该条记录,A事务2次读取的值相同。

该级别无法防住“幻读”,即A事务第一次读取某个范围记录中,B事务在该范围新增一条记录且提交,A事务再次读取该范围记录时,A事务第2次读取的范围值会多一行。

4、可串行化:强制事务串行执行,避免了幻读的问题。该方式是在每一行都加锁,所以可能会存在大量的超时和锁竞争,一般很少用这个级别,

————————————————

版权声明:本文为CSDN博主「九十三大人」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_39471249/article/details/80849740

设置全局的事务隔离级别:SET TRANSACTION ISOLATION LEVEL READ COMMIT; 

设置当前会话的事务隔离级别:SET SESSION TRANSACTION ISOLATION LEVEL READ COMMIT;

相关文章

  • MySQL笔记-锁、事务与并发控制

    MySQL服务器逻辑架构 MySQL并发控制 MySQL死锁问题 MySQL中的事务

  • Mysql事务控制

    事务主要用于处理操作量大,复杂度高的数据 举例说明1:在人员管理系统中,你删除一个人员,你既需要删除人员的基本资料...

  • MySQL事务

    MySQL-innodb-事务 事务的特性 事务的生命周期 失败的事务: 事务的控制语句 面试题 事务日志-red...

  • 1. 高性能MySQL(第三版) -目录

    第一章 MySQL架构与历史 1.1 MySQL逻辑架构 1.2 开发控制 1.3 事务 1.4 多版本并发控制 ...

  • MYSQL事务

    常用语句 MYSQL事务,锁表 事务控制语句 事务的隔离级别 隔离级别描述产生风险READUNCOMMITTED ...

  • 收藏-MySQL

    # MySQL的并发控制与加锁分析# MySQL的四种事务隔离级别# mysql共享锁与排他锁

  • 探秘数据库中的事务

    本文包括:1、事务概念2、MySQL管理事务3、JDBC控制事务进程4、事务的特性(ACID)5、事务的隔离级别6...

  • Mysql事务控制语句

    介绍 Mysql的Innodb存储引擎默认事务都是自动提交(隐式提交);查看当前的事务是否自动提交: 事务操作 开...

  • Mysql并发控制-事务

    Mysql并发控制-事务 事务的特性ACID A: atomiciy 原子性一个事务必须保证其中的操作要么全部执行...

  • 数据库事务,锁

    事务 事务特点ACID 理解ACID 以银行转账为例 MySQL锁 锁是MySQL在服务器层和存储引擎层的并发控制...

网友评论

      本文标题:Mysql事务控制

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