究竟怎么理解Oracle中的物理读,逻辑读,即时读,一致读和读一致性

 我来答
百度网友024827e
推荐于2018-04-23 · TA获得超过1657个赞
知道大有可为答主
回答量:1117
采纳率:93%
帮助的人:354万
展开全部
1. 物理读
这个很容易理解,cpu需要的数据在内存中找不到,那么此时必须去物理磁盘上获取,必然产生物理i/o。
反应在oracle中,就是会话需要某条数据时,在内存的buffer cache中中没有,此时就要去磁盘上的dbf文件中读取。就产生物理读。
2. 逻辑读
这个概念是最清晰,但同时又是最模糊的。
按照计算机原理来讲,逻辑读,表示cpu需要的数据在内存中被找到,数据被直接从内存中传入cpu执行。
3. 即时读(又叫当前读)
按照tom大师的描述:
当前读(Current read):得到块来实际更新所要修改的行时,所完成的获取就是当前读。
这么话怎么理解?
A:读块的时候要加锁。如果读块的目的是为了定位行、然后修改,这时加的锁和纯读的锁并不一样,虽然它们两个都是读操作。
因为加的锁不同,就有了当前读和一致读。
4. 一致读
按照tom大师的描述:
一致读(Consistent read):“发现”要修改的行时,所完成的获取就是一致读。
这么话怎么理解?
A:一致读和当前读放在一起时,一致读指的纯读。
5. 读一致性
这个概念,无庸置疑。
读一致性:Oracle在需要时会使用undo数据来构造CR块,从而提供非阻塞的查询。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式