1. 有物理读的地方,一定会有逻辑读;
物理读:将数据从磁盘上的文件写入到buffer cache的过程;
逻辑读:将数据从
buffer cache
内存读取到PGA给用户的过程
数据库读写的单位是数据块。当用户最终得到的结果可能只是某个数据块中的几行或几列。
当一个查询语句被执行时,服务器进程会将相关的数据块从数据文件中写入内存(buffer cache)。这就叫做 物理读 。每读取一个数据块,即是一次物理读。
而用户需要的并不是整个数据块,而是其中的几行或几列。从buffer cache中提取行的过程,便是逻辑读。
为了完成一次逻辑读,服务器进程先要在hash表中查找块所在的cache buffer链,找到之后,需要在这个链上加一个cache buffer chains闩,加闩成功之后,就在这个链中寻找指定的块,并在块上加一个pin锁,并释放cache buffer chains闩,然后就可以访问块中的行乐。服务器进程不会将块中所有满足条件的行一次取出,而是跟军你的抓取命令,每次取一定数量的行。这些行取出之后,会经由PGA传给客户端用户。行一旦从buffer cache中取出,会话要释放掉在块上所加的pin。本次逻辑读就算结束。如果还要再抓取块中剩余的行,服务器进程要再次申请获得cache bufffer链闩.再次在块上加PIN.这就算是另外一次逻辑读咯.也就是说,服务器进程每申请一次cache buffer链闩,就是一次逻辑读.而每次逻辑读所读取的行的数量,可以在抓取命令中进行设置。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26129555/viewspace-1264818/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26129555/viewspace-1264818/