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数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

如何安装HWE内核? Ubuntu安装hwe内核解决硬件太新的问题

《如何安装HWE内核?Ubuntu安装hwe内核解决硬件太新的问题》今天的主角就是hwe内核(hardwareenablementkernel),一般安装的Ubuntu都是初始内核,不能很好地支... 对于追求系统稳定性,又想充分利用最新硬件特性的 Ubuntu 用户来说,HWEXBQgUbdlna(Har

MAVEN3.9.x中301问题及解决方法

《MAVEN3.9.x中301问题及解决方法》本文主要介绍了使用MAVEN3.9.x中301问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录01、背景02、现象03、分析原因04、解决方案及验证05、结语本文主要是针对“构建加速”需求交

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)