Mysql事务控制

2020-02-17  本文已影响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;

上一篇 下一篇

猜你喜欢

热点阅读