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解决幻读的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/evilcry2013/article/details/79774625
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/724812

相关文章

Java 中的跨域问题解决方法

《Java中的跨域问题解决方法》跨域问题本质上是浏览器的一种安全机制,与Java本身无关,但Java后端开发者需要理解其来源以便正确解决,下面给大家介绍Java中的跨域问题解决方法,感兴趣的朋友一起... 目录1、Java 中跨域问题的来源1.1. 浏览器同源策略(Same-Origin Policy)1.

如何解决yum无法安装epel-release的问题

《如何解决yum无法安装epel-release的问题》:本文主要介绍如何解决yum无法安装epel-release的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录yum无法安装epel-release尝试了第一种方法第二种方法(我就是用这种方法解决的)总结yum

python3 pip终端出现错误解决的方法详解

《python3pip终端出现错误解决的方法详解》这篇文章主要为大家详细介绍了python3pip如果在终端出现错误该如何解决,文中的示例方法讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下... 目录前言一、查看是否已安装pip二、查看是否添加至环境变量1.查看环境变量是http://www.cppcns

idea中project的显示问题及解决

《idea中project的显示问题及解决》:本文主要介绍idea中project的显示问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录idea中project的显示问题清除配置重China编程新生成配置总结idea中project的显示问题新建空的pr

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口

Oracle 通过 ROWID 批量更新表的方法

《Oracle通过ROWID批量更新表的方法》在Oracle数据库中,使用ROWID进行批量更新是一种高效的更新方法,因为它直接定位到物理行位置,避免了通过索引查找的开销,下面给大家介绍Orac... 目录oracle 通过 ROWID 批量更新表ROWID 基本概念性能优化建议性能UoTrFPH优化建议注

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏