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

相关文章

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指