MYSQL进阶之事务
Posted 肝铁侠
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQL进阶之事务相关的知识,希望对你有一定的参考价值。
首先我们要知道事务是什么:
它是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;由一步或几步数据库操作序列组成逻辑执行单元一起向系统提交,要么全部都执行、要么都不执行;事务是一组不可再分割的操作集合。
其次我们要知道事务的四大特性:
①原子性:事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做。
②一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。
③隔离性:一个事务的执行不能被其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
④持续性:也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
事务隔离级别:
①Read-Uncommited:隔离级别值0,会导致脏读。
②Read-Committed:隔离级别值1,避免脏读,允许不可重复读和幻读。
③Repeatable-Read:隔离级别值2,mysql的默认隔离级别,避免脏读,不可重复读,允许幻读。大家可以试着自行查看一下。
④Serializable:隔离级别值3,串行化读,事务只能一个一个执行,避免了 脏读、不可重复读、幻读。执行效率慢,使用时慎重。
那么以上事务隔离级别中所描述的脏读、不可重复读、幻读、串行化读又是什么意思呢?
①脏读:一个事务对数据进行了增删改操作,但是并没有提交事务,那么另一个事务读取这条数据时,就可以读取到未提交事务的数据,如果第一个事务进行了事务回滚,那么第二个事务就读取到了脏数据。(注意MySql是默认的Repeatable-Read级别的事务隔离,在本地实践的话需要变更事务隔离级别才能看到效果)。
②不可重复读:一次事务发生了两次读取操作,但在两次读取操作之间,另一个事务修改了数据,这时候第一次和第二次读取的数据就会不一样。不可重复读关注的是数据更新和删除,通过行级锁可以实现可重复读的隔离级别。
③幻读:指的是当事务在读取某个范围内的数据时,另一个事务在该范围内执行了插入操作,那么就会产生幻读。通过行级锁可以解决不可重复读,但是却不可以解决幻读,要想解决幻读,就智能使用Serializable事务隔离级别来实现。(幻读通俗来讲就是,当你查询某个范围的数据且数据量为2时,另一个事务在这个范围内执行了数据量为1的新增,那么你第一次操作读取到数量为2的结果集,但是在执行下一个操作时,结果集包含了原来的2和新增的1)
④串行化读:Serializable是最高的隔离级别,不仅避免了脏读、不可重复读,还避免了幻读。但是在这种事务隔离级别下,事务是串行顺序执行的,所以效率很低,一般很少使用。
注意,MySQL默认操作模式为自动提交模式
除非显示开启了一个事务,否则每一个增删改查操作都被当做一个单独的事务自动执行。可以通过设置autocommit的值改变默认的提交模式。
今天的分享就到这里吧,欢迎大家一起交流!
以上是关于MYSQL进阶之事务的主要内容,如果未能解决你的问题,请参考以下文章