隨筆 - 3  文章 - 0  trackbacks - 0
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(1)

          隨筆檔案

          文章檔案

          搜索

          •  

          積分與排名

          • 積分 - 1599
          • 排名 - 4227

          最新評論

          閱讀排行榜

          評論排行榜

          What is a subquery?

          A subquery is a query within a query. In Oracle, you can create subqueries within your SQL statements. These subqueries can reside in the WHERE clause, the FROM clause, or the SELECT clause.


          WHERE clause

          Most often, the subquery will be found in the WHERE clause. These subqueries are also called nested subqueries.

          For example:

          select * from all_tables tabs
          where tabs.table_name in (select cols.table_name
           from all_tab_columns cols
           where cols.column_name = 'SUPPLIER_ID');

          Limitations: Oracle allows up to 255 levels of subqueries in the WHERE clause.


          FROM clause

          A subquery can also be found in the FROM clause. These are called inline views.

          For example:

          select suppliers.name, subquery1.total_amt
          from suppliers,
             (select supplier_id, Sum(orders.amount) as total_amt
             from orders
             group by supplier_id) subquery1,
          where subquery1.supplier_id = suppliers.supplier_id;

          In this example, we've created a subquery in the FROM clause as follows:

          (select supplier_id, Sum(orders.amount) as total_amt
           from orders
           group by supplier_id) subquery1

          This subquery has been aliased with the name subquery1. This will be the name used to reference this subquery or any of its fields.

          Limitations: Oracle allows an unlimited number of subqueries in the FROM clause.


          SELECT clause

          A subquery can also be found in the SELECT clause.

          For example:

          select tbls.owner, tbls.table_name,
            (select count(column_name) as total_columns
             from all_tab_columns cols
             where cols.owner = tbls.owner
             and cols.table_name = tbls.table_name) subquery2
          from all_tables tbls;

          In this example, we've created a subquery in the SELECT clause as follows:

          (select count(column_name) as total_columns
           from all_tab_columns cols
           where cols.owner = tbls.owner
           and cols.table_name = tbls.table_name) subquery2

          The subquery has been aliased with the name subquery2. This will be the name used to reference this subquery or any of its fields.

          The trick to placing a subquery in the select clause is that the subquery must return a single value. This is why an aggregate function such as SUM, COUNT, MIN, or MAX is commonly used in the subquery

          posted on 2007-08-14 12:19 y 閱讀(210) 評論(0)  編輯  收藏

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


          網站導航:
           
          主站蜘蛛池模板: 商城县| 南部县| 石城县| 绥江县| 庆安县| 壤塘县| 桃园县| 华阴市| 那坡县| 德令哈市| 汤阴县| 正安县| 临沭县| 钟山县| 敦煌市| 东宁县| 宿迁市| 新野县| 神农架林区| 三江| 昌平区| 石景山区| 商洛市| 右玉县| 双鸭山市| 松阳县| 西藏| 大足县| 邵阳市| 信阳市| 报价| 柯坪县| 安福县| 石林| 肥西县| 旺苍县| 天台县| 金堂县| 客服| 宁武县| 太仆寺旗|