在我们优化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详细在其他的文章介绍。
写到这里,带小孩去玩去了,回来接着写。