隨筆 - 3  文章 - 0  trackbacks - 0
          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          常用鏈接

          留言簿(1)

          隨筆檔案

          文章檔案

          搜索

          •  

          積分與排名

          • 積分 - 1573
          • 排名 - 4239

          最新評論

          閱讀排行榜

          評論排行榜

          Because SQL is a declarative language, you can write the same query in many forms, each getting the same result but with vastly different execution plans and performance.

          In this example, we select all books that do not have any sales.  Note that this is a non-correlated sub-query, but it could be re-written in several ways.

          select
             book_key
          from
             book
          where
             book_key NOT IN (select book_key from sales);
           

          There are serious problems with subqueries that may return NULL values. It is a good idea to discourage the use of the NOT IN clause (which invokes a sub-query) and to prefer NOT EXISTS (which invokes a correlated sub-query), since the query returns no rows if any rows returned by the sub-query contain null values.

          select
             book_key
          from
             book
          where
             NOT EXISTS (select book_key from sales);

          Subqueries can often be re-written to use a standard outer join, resulting in faster performance.  As we may know, an outer join uses the plus sign (+) operator to tell the database to return all non-matching rows with NULL values.  Hence we combine the outer join with a NULL test in the WHERE clause to reproduce the result set without using a sub-query.

          select
             b.book_key
          from
             book  b,
             sales s
          where
             b.book_key = s.book_key(+)
          and
             s.book_key IS NULL;

          This execution plan will also be faster by eliminating the sub-query.

          posted on 2007-08-14 15:06 y 閱讀(206) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 荣昌县| 普安县| 宜良县| 富平县| 富阳市| 榕江县| 诸暨市| 河南省| 凤翔县| 临夏县| 临城县| 沧州市| 浪卡子县| 西乌| 岑巩县| 泰安市| 隆尧县| 广元市| 建平县| 田东县| 启东市| 石渠县| 乌兰察布市| 温泉县| 黑龙江省| 屏东县| 陈巴尔虎旗| 德庆县| 江城| 成安县| 盘山县| 泗阳县| 普格县| 苍溪县| 眉山市| 靖边县| 台江县| 阆中市| 南陵县| 手机| 临城县|