数据库的四种隔离级别
来源:互联网 发布:yy网络怎么创建直播间 编辑:程序博客网 时间:2024/05/19 02:30
未授权读取
也称为读未提交(Read Uncommitted):允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个事务则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。
授权读取
也称为读提交(Read Committed):允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。
可重复读取(Repeatable Read)
可重复读取(Repeatable Read):禁止不可重复读取和脏读取,但是有时可能出现幻读数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。
序列化(Serializable)
序列化(Serializable):提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,不能并发执行。仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。
总结
隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为Read
Committed。它能够避免脏读取,而且具有较好的并发性能。尽管它会导致不可重复读、幻读和第二类丢失更新这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制
。
阅读全文
0 0
- 数据库事务的四种隔离级别
- 数据库的四种隔离级别
- 数据库的四种隔离级别
- 数据库的四种隔离级别
- 数据库的四种隔离级别
- 数据库的四种隔离级别(转载)
- 数据库的四种隔离级别
- 数据库事务的四种隔离级别
- 数据库的四种隔离级别
- 数据库的四种隔离级别
- 数据库四种隔离级别
- 数据库四种隔离级别
- 数据库四种隔离级别
- 数据库四种隔离级别
- 数据库的四种事务隔离级别解析【原创解析】
- 转载-数据库的四种事务隔离级别
- 数据库事务四种隔离级别
- 数据库事务四种隔离级别
- 各种语言获取系统时间
- nglix 1113 错误
- 设计模式--中介者模式
- LeeCode 451. Sort Characters By Frequency
- Mahmoud and a Message CodeForces
- 数据库的四种隔离级别
- 【LeetCode算法练习(C++)】Search in Rotated Sorted Array
- Shell环境和变量生存期
- 设计模式--面向对象设计原则、UML
- 决策树算法以及熵、条件熵、信息增益等整理
- code forces 894C [分割构造gcd]
- [OpenGL] 初识GLFW
- 为ActiveMQ服务器设置安全验证
- Celery-4.1 用户指南: Routing Tasks