数据库事务并发有关问题
2015-08-23 22:03
337 查看
http://blog.csdn.net/kobejayandy/article/details/9166093
多个事务同时访问数据库时候,会发生下列5类问题,包括3类数据读问题(脏读,不可重复读,幻读),2类数据更新问题(第一类丢失更新,第二类丢失更新):
1,脏读(dirty read)
A事务读取B事务尚未提交的更改数据,并在这个数据基础上操作。如果B事务回滚,那么A事务读到的数据根本不是合法的,称为脏读。在oracle中,由于有version控制,不会出现脏读。
2,不可重复读(unrepeatable read)
A事务读取了B事务已经提交的更改(或删除)数据。比如A事务第一次读取数据,然后B事务更改该数据并提交,A事务再次读取数据,两次读取的数据不一样。
3,幻读(phantom read)
A事务读取了B事务已经提交的新增数据。注意和不可重复读的区别,这里是新增,不可重复读是更改(或删除)。这两种情况对策是不一样的,对于不可重复读,只需要采取行级锁防止该记录数据被更改或删除,然而对于幻读必须加表级锁,防止在这个表中新增一条数据。
4,第一类丢失更新
A事务撤销时,把已提交的B事务的数据覆盖掉。这种错误会造成非常严重的后果。
5,第二类丢失更新
A事务提交时,把已提交的B事务的数据覆盖掉。这种错误会造成非常严重的后果。
数据库通过锁机制解决数据并发问题。
ANSI SQL 92标准定义了4个等级的事务隔离级别:
READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE,具体介绍如下:
READ UNCOMMITTED 会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
READ COMMITTED 会出现不可重复读、幻读问题(锁定正在读取的行)
REPEATABLE READ会出幻读(锁定所读取的所有行)
SERIALIZABLE 保证所有的情况不会发生(锁表)
SQL 92 推荐使用REPEATABLE READ 保证数据的读一致性。
多个事务同时访问数据库时候,会发生下列5类问题,包括3类数据读问题(脏读,不可重复读,幻读),2类数据更新问题(第一类丢失更新,第二类丢失更新):
1,脏读(dirty read)
A事务读取B事务尚未提交的更改数据,并在这个数据基础上操作。如果B事务回滚,那么A事务读到的数据根本不是合法的,称为脏读。在oracle中,由于有version控制,不会出现脏读。
2,不可重复读(unrepeatable read)
A事务读取了B事务已经提交的更改(或删除)数据。比如A事务第一次读取数据,然后B事务更改该数据并提交,A事务再次读取数据,两次读取的数据不一样。
3,幻读(phantom read)
A事务读取了B事务已经提交的新增数据。注意和不可重复读的区别,这里是新增,不可重复读是更改(或删除)。这两种情况对策是不一样的,对于不可重复读,只需要采取行级锁防止该记录数据被更改或删除,然而对于幻读必须加表级锁,防止在这个表中新增一条数据。
4,第一类丢失更新
A事务撤销时,把已提交的B事务的数据覆盖掉。这种错误会造成非常严重的后果。
5,第二类丢失更新
A事务提交时,把已提交的B事务的数据覆盖掉。这种错误会造成非常严重的后果。
数据库通过锁机制解决数据并发问题。
ANSI SQL 92标准定义了4个等级的事务隔离级别:
READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE,具体介绍如下:
READ UNCOMMITTED 会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
READ COMMITTED 会出现不可重复读、幻读问题(锁定正在读取的行)
REPEATABLE READ会出幻读(锁定所读取的所有行)
SERIALIZABLE 保证所有的情况不会发生(锁表)
SQL 92 推荐使用REPEATABLE READ 保证数据的读一致性。
相关文章推荐
- 1064 - You have an error in your SQL syntax问题解决
- windows下安装pysqlcipher模块
- SQLite学习笔记(8)-SQLite编译
- mac 下的mysql启动不了
- SQL Server 触发器
- SQL操作表数据_删除操作(delete和truncate)
- Oracle正则表达式使用介绍
- SQLserver游标原理和使用方法
- ogg12c测试oracle 11.2.0.4同步
- postgresql赋予/撤消 用户权限
- SQL Server之存储过程基础知识
- postgresql创建用户
- 连接postgresql数据库
- oracle 存储过程的基本语法
- ORACLE触发器详解
- Oracle 游标使用全解
- Mysql与Oracle区别
- Mybatis实现真正分页查询
- MySQL 存储引擎简介
- Oracle与Sql Server复制表结构和数据