数据库的事务隔离级别
2010-05-19 19:57
239 查看
SERIALIZABLE(序列化,最严格)
:所有的数据库事务都完全隔离,就如系统中所有的事务都顺序执行一样,一个接着一个。当然,数据库可以同时执行多个事务,只要顺序执行的“错觉”可以维护(即同时执行的多个事务不会互相干扰,或者多个事务的同时执行能保证结果的正确)。啥问题也没有,但是效率也基本上是最低的。
REPEATABLE READ(可重复读)
:所有查询到的数据记录都不会被改变。即会在所有获取的数据上加上读锁,但是不会加上范围锁。这个的意思就是说,可能执行两次select count(*) from t返回的值不同,因为这两次执行中有其他事务往t中插入数据。也可以理解成,只对记录加锁,没有表级别的锁。
READ COMMITTED(提交读)
:一个查询所获取的数据可以被其他事务修改。可能出现的问题:在T1事务中第一次读数据A和第二次读数据A的过程中,有个事务修改了A并提交,这就导致两次读到的A的值不一样。
READ UNCOMMITTED(未提交读,相当于没有事务的隔离)
:一个事务可以看见另一个事务所做的未提交修改。
大坑待补。
:所有的数据库事务都完全隔离,就如系统中所有的事务都顺序执行一样,一个接着一个。当然,数据库可以同时执行多个事务,只要顺序执行的“错觉”可以维护(即同时执行的多个事务不会互相干扰,或者多个事务的同时执行能保证结果的正确)。啥问题也没有,但是效率也基本上是最低的。
REPEATABLE READ(可重复读)
:所有查询到的数据记录都不会被改变。即会在所有获取的数据上加上读锁,但是不会加上范围锁。这个的意思就是说,可能执行两次select count(*) from t返回的值不同,因为这两次执行中有其他事务往t中插入数据。也可以理解成,只对记录加锁,没有表级别的锁。
READ COMMITTED(提交读)
:一个查询所获取的数据可以被其他事务修改。可能出现的问题:在T1事务中第一次读数据A和第二次读数据A的过程中,有个事务修改了A并提交,这就导致两次读到的A的值不一样。
READ UNCOMMITTED(未提交读,相当于没有事务的隔离)
:一个事务可以看见另一个事务所做的未提交修改。
大坑待补。
相关文章推荐
- 数据库的事务隔离级别
- 数据库的事务隔离级别
- 数据库事务的四大特性和事务隔离级别以及MVCC
- 数据库中事务隔离级别
- MySQL 数据库 InnoDB 引擎的事务隔离级别
- 数据库的事务并发、事务隔离级别
- Java面试准备十四:数据库——MySQL四种事务隔离级别和锁的关系
- 数据库 事务隔离级别
- 数据库的事务隔离级别
- mssql数据库的事务隔离级别
- 数据库事务的四大特性(ACID)及事务隔离级别
- \t\t数据库的事务隔离级别
- 关系型数据库的事务隔离级别
- 数据库的事务隔离级别和事务传播行为.md
- 数据库的事务隔离级别
- 数据库学习笔记3-oralce 的并发控制与事务隔离级别
- 关于mssql数据库锁和事务隔离级别
- orcal数据库的事务隔离级别
- 数据库的脏数据问题 数据库的事务隔离级别简介
- 数据库的四种事务隔离级别解析【原创解析】