前言
数据库都是有事务的,事务的不同级别,对应数据操作的不同级别安全性。本文以MySql为例介绍一下数据库的事务隔离级别。
事务定义
事务是将数据从一种状态改变到另一种状态。
事务隔离级别是事务看别的事务修改的数据的可见程度。
事务的可见性
脏读 (Dirty read): 一个事务读取到另一个事务还没有提交的数据,又叫无效数据读取。
Example: 事务一对数据进行了增删改等写操作,但还未提交,事务二可以读取到事务一还未提交的数据。这时候事务一Rollback了,事务二读到的就是脏数据。
不可重复读 (Non-repeatable read):在同一个事务内的两次相同的查询,返回不同的数据。
Example: 在同一事务内的第一次读操作和第二次读操作之间,另外一个事务对数据进行了修改,这时候两次读取的数据是不一致的。
不可重复读的重点是修改。同样的条件,两次读取出来的数据不一样。
幻读 (Phantom read):两个对数据进行修改的事务,一个修改,一个新增或删除。
Example: 事务一对一定范围的数据进行批量修改,事务二在这个范围增加或删除了一条数据,这时候第一个事务就会丢失对新增数据的修改。事务一认为出现了幻想。
幻读的重点在于新增或删除。
幻想读是可重复读,区别是 :已读取的数据是不变的,只是看到了更多的数据。
事务的隔离级别
隔离级别 | 隔离级别的值 | 导致的问题 |
Read-Uncommitted | 0 | 导致脏读 |
Read-Committed | 1 | 避免脏读,允许不可重复读和幻读 |
Repeatable-Read | 2 | 避免脏读和不可重复读,允许幻读 |
Serializable | 3 | 串行化读,事务只能一个一个执行,避免了脏读、不可重复读、幻读。执行效率慢,使用时慎重 |
MySql的默认隔离级别是可重复读。
Summary:
隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。
大多数的数据库默认隔离级别为 Read Commited,比如 SqlServer、Oracle、Postgresql。
少数数据库默认隔离级别为:Repeatable Read 比如: MySQL InnoDB。
Tips:
综合而言,因为使用数据库事务隔离级别的成本消耗太大,一般在应用层做事务控制,比如使用乐观锁、分布式事务,来消除在数据库层使用事务的压力。
相关推荐
NULL 博文链接:https://cuishuangjia.iteye.com/blog/964885
MySQL事务隔离级别详解,这个面试经常会面到,必会呀,哈哈
06-VIP-深入理解Mysql事务隔离级别与锁机制.pdf
Mysql事务隔离级别.docx
MySQL事务隔离级别详解.docx
详解Mysql事务隔离级别与锁机制.doc
深入理解Mysql事务隔离级别与锁机制.pdf
4-7深入理解Mysql事务隔离级别与锁机制.mp4
4-6深入理解Mysql事务隔离级别与锁机制.mp4
MySQL的四种事务隔离级别 1、脏读 2、不可重复读 3、幻读
查询:默认事务隔离级别 mysql> select @@tx_isolation;当前会话的默认事务隔离级别 mysql> select @@session.tx_isolation;当前会话的默认事务隔离级别 mysql> select @@global.tx_isolation;全局的事务隔离级别
主要介绍了Mysql事务隔离级别原理实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
数据库事务隔离级别 数据库事务的隔离级别有4个,由低到高依次为 Read uncommitted:允许脏读。 Read committed: 防止脏读,最常用的隔离级别,并且是大多数数据库的默认隔离级别。 Repeatable read:可以防止脏...
然后我们执行上图中的第3步,将事务1中的修改操作进行提交,在事务2中再次查看t1表中的数据(第4步),经过查看发现,t1表中的第2条数据对应的字符串仍然没有发生
查看mysql 事务隔离级别 mysql> show variables like '%isolation%'; +---------------+----------------+ | Variable_name | Value | +---------------+----------------+ | tx_isolation | READ-COMMITTED | +---...
作者:伞U ...好久没碰数据库了,只是想起自己当时在搞数据库的...为了说明问题,我们打开两个控制台分别进行登录来模拟两个用户(暂且成为用户 A 和用户 B 吧),并设置当前 MySQL 会话的事务隔离级别。 一. read unco
事务隔离级别 课程目标 了解 —— 事务隔离级别的概念; 理解 —— 事务隔离的四种级别; 掌握 —— 事务隔离级别的设置; 事务隔离级别 事务隔离:每一个事务都有一个所谓的隔离级,它定义了用户彼此之间隔离和交互...
之前在网上查询mysql事务隔离相关资料,一直只是脑子里有一个印象,久而久之还是会忘记,忘记后又要到网上查找相关资料,但是没实践过就对mysql事务隔离级别理解不是特别的深入,现在自己亲手实践体验一下这个这四个...