在我们优化oracle的时候,经常会用到各种各样的技术手段,其中使用statspack和explain plan是最常见的了。 

当我们使用这两个常见的工具来进行优化调整的时候,经常会看到physical reads和logical reads。 那么这两者 
是什么东东, 他们分别表示什么意思,他们有什么样的区别叻。 

让我们先做一下这样的实验,一起来看看 
SQL>set autotr traceonly; 

SQL> select * from test1.t_1; 

已选择6行。 


引用:

执行计划 
---------------------------------------------------------- 
Plan hash value: 1376489960 

------------------------------------------------------------------------- 
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time 
------------------------------------------------------------------------- 
| 0 | SELECT STATEMENT | | 6 | 234 | 3 (0)| 00:00:01 
| 1 | TABLE ACCESS FULL| T_1 | 6 | 234 | 3 (0)| 00:00:01 
------------------------------------------------------------------------- 
统计信息 
---------------------------------------------------------- 
199 recursive calls 
0 db block gets 
38 consistent gets 
7 physical reads  
0 redo size 
961 bytes sent via SQL*Net to client 
385 bytes received via SQL*Net from client 
2 SQL*Net roundtrips to/from client 
2 sorts (memory) 
0 sorts (disk) 
6 rows processed




这里有个很明显的 
7 physical reads  

我们再来执行以下相同的语句 
SQL> select * from test1.t_1; 

已选择6行。


引用:


执行计划 
---------------------------------------------------------- 
Plan hash value: 1376489960 

------------------------------------------------------------------ 
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Ti 
------------------------------------------------------------------ 
| 0 | SELECT STATEMENT | | 6 | 234 | 3 (0)| 00 
| 1 | TABLE ACCESS FULL| T_1 | 6 | 234 | 3 (0)| 00 
------------------------------------------------------------------ 


统计信息 
---------------------------------------------------------- 
0 recursive calls 
0 db block gets 
8 consistent gets 
0 physical reads  
0 redo size 
961 bytes sent via SQL*Net to client 
385 bytes received via SQL*Net from client 
2 SQL*Net roundtrips to/from client 
0 sorts (memory) 
0 sorts (disk) 
6 rows processed




这里的physical reads已经变化了0 physical reads  

冲这里的实例来看,当我们第一次读取t_1表时,表的数据块是第一次被读取到,读取以后被oracle的加载到buffer中,也就是缓存到SGA的buffer cache中,这个过程是从数据库的物理地址进行读取,读取后加载到内存中,从而这个过程就是我理解的物理读,这里为什么会有7次物理读,而不是6次,不是16次,这个可以在其他的文章中进行研究, 

当第二次我们执行语句的时候,不需要去进行物理山的读了,在buffer中已经缓存了这块数据,我们当然就没有必要去读物理磁盘了,从性能上来说,这是很耗时的。 所以直接从buffer里读就可以了, 既然是从buffer里读,我们就不是一个真实的读了,所以叫做逻辑读。这里就有要引入一个其他的概念,cr(consistent gets),buffer又可能被修改了,或者是因为事务的原因,需要保证读的一致性,这样就需要cr了。cr详细在其他的文章介绍。 

写到这里,带小孩去玩去了,回来接着写。