SQL GROUP BY
子句:為什麼別名不總是有效
SQL 別名增強了可讀性,但它們在 GROUP BY
子句中的使用受到限制。 讓我們檢查一下這個限制。 考慮這個查詢:
<code class="language-sql">SELECT itemName as ItemName, substring(itemName, 1,1) as FirstLetter, Count(itemName) FROM table1 GROUP BY itemName, FirstLetter</code>
此查詢嘗試以別名 FirstLetter
進行分組。 但是,標準 SQL 要求將分組列進行命名,因為它們出現在 FROM
子句中。正確的語法是:
<code class="language-sql">GROUP BY itemName, substring(itemName, 1,1)</code>
這個限制源自於SQL的執行順序:
FROM
WHERE
GROUP BY
HAVING
SELECT
ORDER BY
GROUP BY
子句在 定義別名的 子句之前處理。 因此,在計算 SELECT
時,FirstLetter
還不存在。 GROUP BY
中存在別名時,在 GROUP BY
中使用原始列名稱可能看起來多餘,但它保證了準確的分組。 SELECT
特定於資料庫的變體
一些資料庫系統,例如 MySQL 和 PostgreSQL,提供例外。他們的高階查詢最佳化器可以處理 子句中的別名。 但是,不建議依賴此行為來實現跨資料庫可移植性。 堅持使用標準 SQL 可確保您的查詢在不同資料庫系統中一致運作。 GROUP BY
以上是為什麼不能在 SQL GROUP BY 子句中使用別名?的詳細內容。更多資訊請關注PHP中文網其他相關文章!