1. 程式人生 > 實用技巧 >SQL 查詢語句先執行 SELECT?

SQL 查詢語句先執行 SELECT?

SELECT語句的完整語法:

SELECT 
DISTINCT <select_list>
FROM <left_table>
<join_type> JOIN <right_table>
ON <join_condition>
WHERE <where_condition>
GROUP BY <group_by_list>
HAVING <having_condition>
ORDER BY <order_by_condition>
LIMIT <limit_number>

  

執行順序:

FROM
<表名> # 笛卡爾積
ON
<篩選條件> # 對笛卡爾積的虛表進行篩選
JOIN <join, left join, right join...>
<join表> # 指定join,用於新增資料到on之後的虛表中,例如left join會將左表的剩餘資料新增到虛表中
WHERE
<where條件> # 對上述虛表進行篩選
GROUP BY
<分組條件> # 分組
<SUM()等聚合函式> # 用於having子句進行判斷,在書寫上這類聚合函式是寫在having判斷裡面的
HAVING
<分組篩選> # 對分組後的結果進行聚合篩選 SELECT <返回資料列表> # 返回的單列必須在group by子句中,聚合函式除外 DISTINCT # 資料除重 ORDER BY <排序條件> # 排序 LIMIT <行數限制>

引擎在執行上述每一步時,都會在記憶體中形成一張虛擬表,然後對虛擬表進行後續操作,並釋放沒用的虛擬表的記憶體,以此類推。

具體解釋:(注:下面“VT”表示 → 虛擬表 virtual )

  1. from:select * from table_1, table_2; 與 select * from table_1 join table_2; 的結果一致,都是表示求笛卡爾積;用於直接計算兩個表笛卡爾積,得到虛擬表VT1,這是所有select語句最先執行的操作,其他操作時在這個表上進行的,也就是from操作所完成的內容
  2. on: 從VT1表中篩選符合條件的資料,形成VT2表;
  3. join: 將該 join 型別的資料補充到VT2表中,例如 left join 會將左表的剩餘資料新增到虛表VT2中,形成VT3表;若表的數量大於2,則會重複1-3步;
  4. where: 執行篩選,(不能使用聚合函式)得到VT4表;
  5. group by: 對VT4表進行分組,得到VT5表;其後處理的語句,如select,having,所用到的列必須包含在group by條件中,沒有出現的需要用聚合函式;
  6. having: 篩選分組後的資料,得到VT6表;
  7. select: 返回列得到VT7表;
  8. distinct: 用於去重得到VT8表;
  9. order by: 用於排序得到VT9表;
  10. limit: 返回需要的行數,得到VT10;
  • 需要注意的是:

    • group by條件中,每個列必須是有效列,不能是聚合函式;
    • null值也會作為一個分組返回;
    • 除了聚合函式,select子句中的列必須在group by條件中;

原博文連結:https://blog.csdn.net/qq_39390545/article/details/105893049

路漫漫其修遠今,吾將上下而求索。--屈原。