zoukankan      html  css  js  c++  java
  • Oracle in和exists效率问题分析

    --------------------------in和exists效率问题-------------

    单说in和exsist,in的效率较差。
    关于EXISTS与IN的区别:
    EXISTS检查是否有结果,判断是否有记录,返回的是一个布尔型(TRUE/FALSE)。
    IN是对结果值进行比较,判断一个字段是否存在于几个值的范围中,所以 EXISTS 比 IN 快。

    主要区别是:
    exists主要用于片面的,有满足一个条件的即可,
    in主要用于具体的集合操作,有多少满足条件.

    exists是判断是否存在这样的记录,
    in是判断某个字段是否在指定的某个范围内。
    exists快一些。

    注意有时不一定的:in适合内外表都很大的情况,exists适合外表结果集很小的情况。

    ------------------ 查找前十条性能差的sql----------------------

    脚本:查找前十条性能差的sql
    SELECT * FROM (select PARSING_USER_ID,EXECUTIONS,SORTS,
      COMMAND_TYPE,DISK_READS,sql_text FROM v$sqlarea
      order BY disk_reads DESC )where ROWNUM<10 ;

  • 相关阅读:
    单调栈模板
    Yet Another Broken Keyboard[双指针]
    经典递归集合
    [未完成]ECRound 80
    #614 C. NEKO's Maze Game[简易DFS,0|1转换]
    等差数列异或和模板
    线段树基础题
    前缀和&差分
    优先队列
    st表模板
  • 原文地址:https://www.cnblogs.com/qqzy168/p/3153359.html
Copyright © 2011-2022 走看看