博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

查看SQL执行计划

Posted on 2016-11-09 14:36  sky410  阅读(190)  评论(0编辑  收藏  举报

一用户进入某界面慢得要死,查看SQL执行计划如下(具体SQL语句就不完全公布了,截断的如下):

 

 

[sql] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. call     count       cpu    elapsed       disk      query    current        rows  
  2. ------- ------  -------- ---------- ---------- ---------- ----------  ----------  
  3. Parse        1      0.00       0.00          0          0          0           0  
  4. Execute      1      0.00       0.00          0          0          0           0  
  5. Fetch        1      9.48      97.10       4222     163337          0           0  
  6. ------- ------  -------- ---------- ---------- ---------- ----------  ----------  
  7. total        3      9.48      97.10       4222     163337          0           0  
  8.   
  9. Misses in library cache during parse: 0  
  10. Optimizer mode: ALL_ROWS  
  11. Parsing user id: 31    
  12. Number of plan statistics captured: 1  
  13.   
  14. Rows (1st) Rows (avg) Rows (max)  Row Source Operation  
  15. ---------- ---------- ----------  ---------------------------------------------------  
  16.          0          0          0  SORT ORDER BY (cr=163337 pr=4222 pw=0 time=97103852 us)  
  17.          0          0          0   HASH GROUP BY (cr=163337 pr=4222 pw=0 time=97103834 us)  
  18.          0          0          0    NESTED LOOPS  (cr=163337 pr=4222 pw=0 time=97103700 us)  
  19.          0          0          0     NESTED LOOPS  (cr=163337 pr=4222 pw=0 time=97103697 us)  
  20.          6          6          6      NESTED LOOPS  (cr=163300 pr=4222 pw=0 time=100235764 us)  
  21.        373        373        373       FILTER  (cr=163298 pr=4222 pw=0 time=159317332 us)  
  22.        373        373        373        HASH JOIN RIGHT OUTER (cr=163298 pr=4222 pw=0 time=92520264 us)  
  23.        608        608        608         TABLE ACCESS FULL 病历文件列表 (cr=23 pr=0 pw=0 time=51 us)  
  24.        373        373        373         TABLE ACCESS FULL 电子病历记录 (cr=163275 pr=4222 pw=0 time=92510188 us)  
  25.          6          6          6       INDEX UNIQUE SCAN 病区科室对应_PK (cr=2 pr=0 pw=0 time=1713 us)(object id 19144)  
  26.          0          0          0      TABLE ACCESS BY INDEX ROWID 病人变动记录 (cr=37 pr=0 pw=0 time=478 us)  
  27.         23         23         23       INDEX RANGE SCAN 病人变动记录_IX_病人ID (cr=15 pr=0 pw=0 time=128 us)(object id 19148)  
  28.          0          0          0     TABLE ACCESS BY INDEX ROWID 病人信息 (cr=0 pr=0 pw=0 time=0 us)  
  29.          0          0          0      INDEX UNIQUE SCAN 病人信息_PK (cr=0 pr=0 pw=0 time=0 us)(object id 19355)  


可以清楚的看到,2个表全表扫描,而且电子病历记录是一张大表,记录数据接近千万,这样查询要死人的,查看谓语条件,电子病历记录表有“完成时间>=Trunc(Sysdate-(:V001-1))”,如果用到该字段的索引,肯定能够提升查询的性能,最后调整后的执行计划如下:

 

分分钟查询结果出来,问题解决。