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

相关文章

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

深入理解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没有找到