• 查看SQL执行计划


    一用户进入某界面慢得要死,查看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))”,如果用到该字段的索引,肯定能够提升查询的性能,最后调整后的执行计划如下:

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

  • 相关阅读:
    JDK -GET,POST
    (三十四)什么是自动化测试模型之模块化驱动测试实例
    Linux 运维命令及知识
    python_检测一些特定的服务端口有没有被占用
    程序员常用网站
    网络安全与CTF在线学习资源网站
    MySQL_语句
    python脚本实现自动安装nginx
    超赞的Linux软件
    Python运维中常用的_脚本
  • 原文地址:https://www.cnblogs.com/skyay/p/6046880.html
Copyright © 2020-2023  润新知