全部產品
Search
文件中心

PolarDB:SELECT

更新時間:Jul 06, 2024

SELECT用於從一個或多個表中查詢資料。

文法

SELECT
    [ALL | DISTINCT]
    select_expr [, select_expr ...]
    [FROM table_references
    [WHERE where_condition]
    [GROUP BY {col_name | expr | position}
    [HAVING where_condition]
    [ORDER BY {col_name | expr | position}
      [ASC | DESC], ...]
    [LIMIT {[offset,] row_count | row_count OFFSET offset}]
    [FOR UPDATE]
SELECT子句說明:
  • select_expr:表示查詢的列,SELETE必須至少有一個select_expr;
  • table_references:表示從哪些表中擷取資料;
  • WHERE子句:指定查詢條件,即從表中擷取滿足”where_condition“的行,若沒有指定,則擷取所有行;
  • GROUP BY子句:支援列名,運算式以及輸出資料行中的位置引用;
  • HAVING子句:與WHERE類似,不同點在於可以使用彙總函式;
  • ORDER BY:指定排序,支援列名、運算式以及輸出資料行中的位置引用,同時支援指定排序方向,ASC(升序)或 DESC(降序);
  • LIMIT/OFFSET:限定輸出結果集的位移量和大小。LIMIT 接受一個或兩個數字參數。參數必須是一個整數常量。如果給定兩個參數,第一個參數指定第一個返回記錄行的位移量,第二個參數指定返回記錄行的最大數目。初始記錄行的位移量是0(而不是1): 為了與PostgreSQL相容,MySQL也支援句法: LIMIT # OFFSET #;
  • FOR UPDATE:對查詢結果所有行加獨佔鎖定,以阻止其他事務的並發修改,或阻止在某些交易隔離等級時的並發讀取。

注意事項

  • 不支援在HAVING中使用適用於WHERE子句的運算式,如下SQL1應改寫為SQL2。
    SQL1:
    SELECT col_name FROM tbl_name HAVING col_name > 0;
    SQL2:
    SELECT col_name FROM tbl_name WHERE col_name > 0;
  • HAVING子句可以引用彙總函式,但WHERE子句不可以。
    SELECT user, MAX(salary) FROM users
      GROUP BY user HAVING MAX(salary) > 10; 
  • LIMIT若有兩個參數,第一個參數表示返回第一行的位移量,第二個參數表示返回的行數;若僅有一個參數,則表示返回的行數,預設位移量為0。
  • GROUP BY子句不支援ASC和DESC。
  • 同時存在GROUP BY和ORDER BY時,ORDER BY後面的運算式必須在SELECT運算式或GROUP BY運算式中,如不支援以下SQL。
    SELECT user FROM users GROUP BY age ORDER BY salary;     
  • 暫不支援ORDER BY子句中使用彙總函式以及包含彙總函式的運算式,可將運算式作為”select_expr“,並賦予別名,在ORDER BY子句中引用該別名。
  • 暫不支援以Null 字元串作為別名。

JOIN

PolarDB-X 1.0支援在SELECT語句的table_references中使用如下JOIN文法:

table_references:
    escaped_table_reference [, escaped_table_reference] ...

escaped_table_reference:
    table_reference
  | { OJ table_reference }

table_reference:
    table_factor
  | join_table

table_factor:
    [schema_name.]tbl_name [[AS] alias] [index_hint_list]
  | table_subquery [AS] alias
  | ( table_references )

join_table:
    table_reference [INNER | CROSS] JOIN table_factor [join_condition]
  | table_reference {LEFT|RIGHT} [OUTER] JOIN table_reference join_condition

join_condition:
    ON conditional_expr
  | USING (column_list)

index_hint_list:
    index_hint [, index_hint] ...

index_hint:
    USE {INDEX|KEY}
      [FOR {JOIN|ORDER BY|GROUP BY}] ([index_list])
  | IGNORE {INDEX|KEY}
      [FOR {JOIN|ORDER BY|GROUP BY}] (index_list)
  | FORCE {INDEX|KEY}
      [FOR {JOIN|ORDER BY|GROUP BY}] (index_list)

index_list:
    index_name [, index_name] ...
            

使用JOIN語句時,應考慮如下因素:

  • JOIN、CROSS JOIN與INNER JOIN文法是等價的,這種設定與MySQL保持一致。
  • 如果INNER JOIN沒有ON條件,其與”逗號“串連是等價的,均表示笛卡爾積。如下兩條SQL等價:
    SELECT * FROM t1 INNER JOIN t2 WHERE t1.id > 10
    SELECT * FROM t1, t2 WHERE t1.id > 10      
  • USING(column_list)指定串連兩表中都存在的列名,PolarDB-X 1.0會按照這些列構建等值條件。如下兩條SQL等價:
    a LEFT JOIN b USING(c1, c2)
    a LEFT JOIN b ON a.c1 = b.c1 AND a.c2 = b.c2
                
  • JOIN的優先順序高於”逗號“操作符,對於串連運算式t1, t2 JOIN t3會轉換為(t1, (t2 JOIN t3)),而不是((t1, t2) JOIN t3)
  • 外串連LEFT/RIGHT JOIN必須有ON條件。
  • index_hint用於告知MySQL使用哪個索引,PolarDB-X 1.0會將該Hint下推至底層MySQL。
  • 暫不支援STRAIGHT_JOIN和NATURAL JOIN。

UNION

PolarDB-X 1.0支援如下UNION文法:

SELECT ...
UNION [ALL | DISTINCT] SELECT ...
[UNION [ALL | DISTINCT] SELECT ...]        
說明 對於UNION中的每個SELECT,PolarDB-X 1.0暫不支援使用多個同名的列。例如以下SQL的SELECT中存在重複的列名,暫不支援。
SELECT id, id, name FROM t1 UNION SELECT pk, pk, name FROM t2;          

相關文檔