Oracle解决幻读的理解

2024-02-19 13:30
文章标签 oracle 理解 解决 幻读

本文主要是介绍Oracle解决幻读的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



收藏 |  打印  上一主题  下一主题

[辩论] Oracle解决幻读的理解 

[复制链接]
stevendba
认证徽章
论坛徽章:
22
ITPUB 11周年纪念徽章日期:2012-10-09 18:16:00 天枰座日期:2016-01-18 10:58:39 马上加薪日期:2014-10-21 18:48:25 马上加薪日期:2014-10-21 18:48:31 2015年新春福章日期:2015-03-04 14:53:16 2015年新春福章日期:2015-03-06 11:58:39 沸羊羊日期:2015-06-11 17:08:14 巨蟹座日期:2015-07-10 09:11:44 秀才日期:2016-02-18 10:08:14 秀才日期:2016-06-23 14:15:06
跳转到指定楼层
1#
  发表于 2015-9-23 12:42  |  只看该作者  回帖奖励
本帖最后由 stevendba 于 2015-9-23 12:43 编辑

     最近在看《mysql 技术内幕 innoDB存储引擎》第二版,第260页有一句话,原话是:如Oracle数据库,因为其可能需要在SERIALIZABLE的事务隔离级别下才能解决Phantom Problem。我认为这句话不对。          

     Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读。说一场景:
     假设8:00发起一个select,10s后才能扫描完全表,但在8:01的时候,有事务向这个表中插入了数据且提交了。Oracle是看不到,因为Oracle在扫描表的时候会对比发出时间的SCN(8:00)和block中的SCN,如果发现block scn > 发出select的SCN,此时说明数据块被修改了,就会到undo中构造一致性数据块,从而解决了幻读。
     请问,我的理解有没有问题?


  • 本版精华
  • Jonathan Lewis关于CBO的系列文章
  • [翻译]11gR2 新特性:在线版本变更(Edition-Based Redefinition)
  • [翻译]Oracle 12c R2优化器白皮书
  • 【好东西还是留在本版】我多年收藏的各种语言编码规范
  • Oracle PLSQL读取(解析)Excel文档
  • 求反GROUP BY的写法
  • 受lastwinner邀请,尝试作答第三届SQL大赛第一道题
  • 我也玩个游戏,我申请加精,求批准
  • 这几年牛蛙写过的奇葩代码
  • 开发版常见问题集锦
 

使用道具 举报

回复
   
Naldonado
认证徽章
论坛徽章:
168
SQL数据库编程大师日期:2016-01-13 10:30:43 SQL极客日期:2013-12-09 14:13:35 SQL大赛参与纪念日期:2013-12-06 14:03:45 最佳人气徽章日期:2015-03-19 09:44:03 现任管理团队成员日期:2015-08-26 02:10:00 秀才日期:2015-07-28 09:12:12 举人日期:2015-07-13 15:30:15 进士日期:2015-07-28 09:12:58 探花日期:2015-07-28 09:12:58 榜眼日期:2015-08-18 09:48:03
2#
  发表于 2015-9-23 13:25  |  只看该作者
"Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读"

不对的,读提交的情况下是允许幻读和不可重复读的。
 
 

使用道具 举报

回复
   
Naldonado
认证徽章
论坛徽章:
168
SQL数据库编程大师日期:2016-01-13 10:30:43 SQL极客日期:2013-12-09 14:13:35 SQL大赛参与纪念日期:2013-12-06 14:03:45 最佳人气徽章日期:2015-03-19 09:44:03 现任管理团队成员日期:2015-08-26 02:10:00 秀才日期:2015-07-28 09:12:12 举人日期:2015-07-13 15:30:15 进士日期:2015-07-28 09:12:58 探花日期:2015-07-28 09:12:58 榜眼日期:2015-08-18 09:48:03
3#
  发表于 2015-9-23 13:27  |  只看该作者
此外你说的这种情况也不叫幻读,叫一致读。。。

幻读定义:
幻读是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,比如这种修改涉及到表中的"全部数据行"。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入"一行新数据"。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样.一般解决幻读的方法是增加范围锁RangeS,锁定检锁范围为只读,这样就避免了幻读。

往往跟应用更新全部数据行有关。。。for update来解决
 
 

使用道具 举报

回复
   
lcpp8
论坛徽章:
34
ITPUB8周年纪念徽章日期:2015-09-11 12:12:40 懒羊羊日期:2015-03-16 16:11:09 处女座日期:2015-09-06 15:45:26 慢羊羊日期:2015-03-30 09:30:27 喜羊羊日期:2015-04-22 14:38:35 慢羊羊日期:2015-05-15 09:22:38 双鱼座日期:2015-07-16 13:16:54 慢羊羊日期:2015-06-19 09:29:03 双子座日期:2015-08-27 13:16:31 金牛座日期:2015-11-02 09:28:35
4#
  发表于 2015-9-23 13:55  |  只看该作者
整点查询,1分更新并提交,10分出结果,查询的结果里面不包含1分时更新的数据,这叫一致性读。
 
 

使用道具 举报

回复
   
stevendba
认证徽章
论坛徽章:
22
ITPUB 11周年纪念徽章日期:2012-10-09 18:16:00 天枰座日期:2016-01-18 10:58:39 马上加薪日期:2014-10-21 18:48:25 马上加薪日期:2014-10-21 18:48:31 2015年新春福章日期:2015-03-04 14:53:16 2015年新春福章日期:2015-03-06 11:58:39 沸羊羊日期:2015-06-11 17:08:14 巨蟹座日期:2015-07-10 09:11:44 秀才日期:2016-02-18 10:08:14 秀才日期:2016-06-23 14:15:06
5#
  发表于 2015-9-23 14:15  |  只看该作者
Naldonado 发表于 2015-9-23 13:25 
"Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读"

不对 ...

你说的是对的,我说的场景与幻读不是一个场景。想想,幻读和不可重复读有没有问题,要看业务。
 
 

使用道具 举报

回复
   

〇〇
论坛徽章:
397
兰博基尼日期:2013-12-15 15:36:43 2014年世界杯参赛球队: 洪都拉斯日期:2014-06-25 08:25:55 itpub13周年纪念徽章日期:2014-09-28 10:55:55 itpub13周年纪念徽章日期:2014-10-01 15:27:22 itpub13周年纪念徽章日期:2014-10-09 12:04:18 马上有钱日期:2014-10-14 21:37:37 马上有钱日期:2015-01-22 00:39:13 喜羊羊日期:2015-02-20 22:26:07 懒羊羊日期:2015-02-21 22:03:31 懒羊羊日期:2015-03-04 14:52:11
6#
  发表于 2015-9-23 19:24  来自手机  |  只看该作者
lcpp8 发表于 2015-9-23 13:55
整点查询,1分更新并提交,10分出结果,查询的结果里面不包含1分时更新的数据,这叫一致性读。

超过时间出不来,就会出现快照太旧错误
 
收藏 |  打印  上一主题  下一主题

[辩论] Oracle解决幻读的理解 

[复制链接]
stevendba
认证徽章
论坛徽章:
22
'ITPUB 11周年纪念徽章 '天枰座 '马上加薪 '马上加薪 '2015年新春福章 '2015年新春福章 '沸羊羊 '巨蟹座 '秀才 '秀才
跳转到指定楼层
1#
  发表于 2015-9-23 12:42  |  只看该作者  回帖奖励
本帖最后由 stevendba 于 2015-9-23 12:43 编辑

     最近在看《mysql 技术内幕 innoDB存储引擎》第二版,第260页有一句话,原话是:如Oracle数据库,因为其可能需要在SERIALIZABLE的事务隔离级别下才能解决Phantom Problem。我认为这句话不对。          

     Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读。说一场景:
     假设8:00发起一个select,10s后才能扫描完全表,但在8:01的时候,有事务向这个表中插入了数据且提交了。Oracle是看不到,因为Oracle在扫描表的时候会对比发出时间的SCN(8:00)和block中的SCN,如果发现block scn > 发出select的SCN,此时说明数据块被修改了,就会到undo中构造一致性数据块,从而解决了幻读。
     请问,我的理解有没有问题?


  • 本版精华
  • Jonathan Lewis关于CBO的系列文章
  • [翻译]11gR2 新特性:在线版本变更(Edition-Based Redefinition)
  • [翻译]Oracle 12c R2优化器白皮书
  • 【好东西还是留在本版】我多年收藏的各种语言编码规范
  • Oracle PLSQL读取(解析)Excel文档
  • 求反GROUP BY的写法
  • 受lastwinner邀请,尝试作答第三届SQL大赛第一道题
  • 我也玩个游戏,我申请加精,求批准
  • 这几年牛蛙写过的奇葩代码
  • 开发版常见问题集锦
 

使用道具 举报

回复
   
Naldonado
认证徽章
论坛徽章:
168
'SQL数据库编程大师 'SQL极客 'SQL大赛参与纪念 '最佳人气徽章 '现任管理团队成员 '秀才 '举人 '进士 '探花 '榜眼
2#
  发表于 2015-9-23 13:25  |  只看该作者
"Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读"

不对的,读提交的情况下是允许幻读和不可重复读的。
 
 

使用道具 举报

回复
   
Naldonado
认证徽章
论坛徽章:
168
'SQL数据库编程大师 'SQL极客 'SQL大赛参与纪念 '最佳人气徽章 '现任管理团队成员 '秀才 '举人 '进士 '探花 '榜眼
3#
  发表于 2015-9-23 13:27  |  只看该作者
此外你说的这种情况也不叫幻读,叫一致读。。。

幻读定义:
幻读是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,比如这种修改涉及到表中的"全部数据行"。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入"一行新数据"。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样.一般解决幻读的方法是增加范围锁RangeS,锁定检锁范围为只读,这样就避免了幻读。

往往跟应用更新全部数据行有关。。。for update来解决
 
 

使用道具 举报

回复
   
lcpp8
论坛徽章:
34
'ITPUB8周年纪念徽章 '懒羊羊 '处女座 '慢羊羊 '喜羊羊 '慢羊羊 '双鱼座 '慢羊羊 '双子座 '金牛座
4#
  发表于 2015-9-23 13:55  |  只看该作者
整点查询,1分更新并提交,10分出结果,查询的结果里面不包含1分时更新的数据,这叫一致性读。
 
 

使用道具 举报

回复
   
stevendba
认证徽章
论坛徽章:
22
'ITPUB 11周年纪念徽章 '天枰座 '马上加薪 '马上加薪 '2015年新春福章 '2015年新春福章 '沸羊羊 '巨蟹座 '秀才 '秀才
5#
  发表于 2015-9-23 14:15  |  只看该作者
Naldonado 发表于 2015-9-23 13:25 
"Oracle默认的事务隔离级别是read commited,在此级别下,通过多版本的控制解决了幻读和不可重复读"

不对 ...

你说的是对的,我说的场景与幻读不是一个场景。想想,幻读和不可重复读有没有问题,要看业务。
 
 

使用道具 举报

回复
   

〇〇
论坛徽章:
397
'兰博基尼 '2014年世界杯参赛球队: 洪都拉斯 'itpub13周年纪念徽章 'itpub13周年纪念徽章 'itpub13周年纪念徽章 '马上有钱 '马上有钱 '喜羊羊 '懒羊羊 '懒羊羊
6#
  发表于 2015-9-23 19:24  来自手机  |  只看该作者
lcpp8 发表于 2015-9-23 13:55
整点查询,1分更新并提交,10分出结果,查询的结果里面不包含1分时更新的数据,这叫一致性读。

超过时间出不来,就会出现快照太旧错误
 

这篇关于Oracle解决幻读的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/724812

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法

《Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法》本文解析Spring框架中BeanCreationExce... 目录引言一、问题描述1.1 报错示例假设我们有一个简单的Java类,代表一个用户信息的实体类:然后,

MySQL磁盘空间不足问题解决

《MySQL磁盘空间不足问题解决》本文介绍查看空间使用情况的方式,以及各种空间问题的原因和解决方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录查看空间使用情况Binlog日志文件占用过多表上的索引太多导致空间不足大字段导致空间不足表空间碎片太多导致空间不足临时表空间