Chinaunix首页 | 论坛 | 博客
  • 博客访问: 405889
  • 博文数量: 38
  • 博客积分: 1490
  • 博客等级: 上尉
  • 技术积分: 406
  • 用 户 组: 普通用户
  • 注册时间: 2006-01-08 00:52
文章分类

全部博文(38)

文章存档

2014年(1)

2013年(1)

2008年(6)

2007年(7)

2006年(23)

我的朋友

分类: Java

2008-01-18 14:13:12

关于事务

什么是事务?

事务通常是针对数据库处理中所发生的一件事,这件事在处理过程中要保证相关的数据和操作要完整、准确、安全。对于也就是说事务要具备原子性、一致性、隔离性和持久性,其中:

原子性是指单个事务中的操作是不可以被打断的,要么全成功,要么全回滚,不可以只完成部分。

一致性是指单个事务中的数据是对其他并发事务是不可见的,也就是说在事务未完成前其中数据是私有的,对外不可见。

隔离性是指并发的事务之间是互相不干扰的。

持久性是指事务的结果是可持久化的,结果不会消失。

 

并发事务可能引起的问题?

1.                Lost update:指AB事务并发,A更新提交,B对同一目标数据更新,在A完成提交之前B回滚,则A的更新也消失。

2.                Dirty readAB事务并发执行,A更新库中数据,在未完成提交时,B读同一数据,可能会读到A更新的数据,此后,A回滚,那么B读的数据就不是数据库中的数据,此现象为脏读。

3.                Unrepeatable readAB事务并发,A读库中数据,此时B更新同一数据,A再次读同一数据,但是发现两次读的不一样,此现象为不可重复读。(还有一种情况也是不可重复读:A更新数据,B更新同一数据,A再读该数据,发现数据变了。)

4.                Phantom readAB事务并发,A读数据的过程中,B在插入或更新数据,此时A会读到库中原来有的数据不见的,新的数据凭空出现了。

 

事务隔离级别?

为了解决事务并发可能引起的问题,要使用到事务隔离级别。有四种隔离级别:

1.               read uncommitted isolation:不允许(1)问题存在,允许(2)问题存在。写事务执行时不允许同时有其他的写事务并发执行。

2.               read committed isolation:不允许(2)问题存在,允许(3)问题存在。读事务允许其他事务并发执行,没有提交的写事务执行时不允许同时有其他并发事务执行。

3.               repeatable read isolation:不允许(3)问题存在,允许(4)问题存在。读事务不允许写事务并发执行,没有提交的写事务执行时不允许同时有其他并发事务执行。

4.               Serializable:完全解决问题。

阅读(2103) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~