事务隔离级别

事务隔离级别

ID:36366693

大小:474.50 KB

页数:13页

时间:2019-05-10

事务隔离级别_第1页
事务隔离级别_第2页
事务隔离级别_第3页
事务隔离级别_第4页
事务隔离级别_第5页
资源描述:

《事务隔离级别》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、事务隔离级别  在JDBC操作中,为了有效保证并发读取数据的正确性,提出的事务隔离级别的概念。  问题的提出:数据库是要被广大客户所共享访问的,那么在数据库操作过程中很可能出现以下几种不确定情况。  ●更新丢失(Lostupdate):两个事务都同时更新一行数据,但是第二个事务却中途失败退出,导致对数据的两个修改都失效了。这是因为系统没有执行任何的锁操作,因此并发事务并没有被隔离开来。  ●脏读(DirtyReads):一个事务开始读取了某行数据,但是另外一个事务已经更新了此数据但没有能够及时提交。这是

2、相当危险的,因为很可能所有的操作都被回滚。  ●不可重复读(Non-repeatableReads):一个事务对同一行数据重复读取两次,但是却得到了不同的结果。例如,在两次读取的中途,有另外一个事务对该行数据进行了修改,并提交。  ●两次更新问题(Secondlostupdatesproblem):无法重复读取的特例。有两个并发事务同时读取同一行数据,然后其中一个对它进行修改提交,而另一个也进行了修改提交。这就会造成第一次写操作失效。  ●幻读(PhantomReads):事务在操作过程中进行两次查询,

3、第二次查询的结果包含了第一次查询中未出现的数据(这里并不要求两次查询的SQL语句相同)。这是因为在两次查询过程中有另外一个事务插入数据造成的。  解决方案:为了避免上面出现的几种情况,在标准SQL规范中,定义了4个事务隔离级别,不同的隔离级别对事务的处理不同。  ●未授权读取,也称为读未提交(ReadUncommitted):允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个数据则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。  ●授权读取,也称为

4、读提交(ReadCommitted):允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。  ●可重复读取(RepeatableRead):禁止不可重复读取和脏读取,但是有时可能出现幻影数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。  ●序列化(Serializable):提供严格的事务隔离。它要求事务序列化执行,事

5、务只能一个接着一个地执行,但不能并发执行。如果仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。  隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为ReadCommitted,它能够避免脏读取,而且具有较好的并发性能。尽管它会导致不可重复读、虚读和第二类丢失更新这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制。关于可重复读:问题:“可

6、重复读”一般被解释成“是个事务多次读取数据,读的结果一致,不会读到别的事务提交的数据”。。。请问:这个解释真的正确吗?1是另一个事务提交了,这个事务读不到,还是说:2在这个事务没有还没有commit之前,另外一个事务不能进行update,insert,delete操作??答案是1还是2?或者都不是,请高手赐教了。。答案是2可重复读隔离级别是最严格的隔离级别。在该隔离级别下,一个事务的影响完全与其他并发事务隔离,脏读、不可重复的读、幻像读现象都不会发生。当使用可重复读隔离级别时,在事务执行期间会锁定该事务

7、以任何方式引用的所有行。因此,如果在同一个事务中发出同一个SELECT语句两次或更多次,那么产生的结果数据集总是相同的。因此,使用可重复读隔离级别的事务可以多次检索同一行集,并对它们执行任意操作,直到提交或回滚操作终止该事务。但是,在事务存在期间,不允许其他事务执行会影响这个事务正在访问的任何行的插入、更新或删除操作。为了确保这种行为不会发生,锁定该事务所引用的每一行--而不是仅锁定被实际检索或修改的那些行。因此,如果一个事务扫描了1000行,但只检索10行,那么它所扫描的1000行(而不仅是被检索的1

8、0行)都会被锁定。隔离级别中的重复读是是指在第一次读出数据后数据被修改了但第二次去读为保证数据一致,还是与第一次读的一样,这是比较高的隔离级别。还有一个比它高的幻影读是即使你添加列等操作都读不出来[转载]微软SQLServer事务隔离级别实例简介作者:EdisonZhu  来源:博客园  发布时间:2009-11-1223:56  阅读:173次  原文链接  [收藏]  源文: http://untitled.spaces.live.co

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。