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

          常用鏈接

          留言簿(1)

          隨筆檔案

          文章檔案

          搜索

          •  

          積分與排名

          • 積分 - 1573
          • 排名 - 4239

          最新評論

          閱讀排行榜

          評論排行榜

          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 閱讀(207) 評論(0)  編輯  收藏

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


          網站導航:
           
          主站蜘蛛池模板: 台前县| 霍林郭勒市| 汪清县| 贵溪市| 农安县| 吉安市| 资中县| 久治县| 二连浩特市| 宁安市| 青川县| 娄底市| 三亚市| 平阳县| 二连浩特市| 宁安市| 乌拉特后旗| 高台县| 汶川县| 郯城县| 丰县| 大埔区| 新田县| 南和县| 大英县| 瑞金市| 韶山市| 宾川县| 鄂托克前旗| 南开区| 霍林郭勒市| 龙岩市| 犍为县| 大埔区| 石楼县| 前郭尔| 连山| 都江堰市| 镇安县| 剑阁县| 孟津县|