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
是 SELECT
子句中定義的別名,在 GROUP BY
子句中使用。 正確的做法是在 substring(itemName, 1,1)
子句中使用實際的表達式 GROUP BY
。
此限制的原因源自於標準 SQL 處理順序:
FROM
WHERE
GROUP BY
HAVING
SELECT
ORDER BY
由於 GROUP BY
子句是在 子句之前執行的,因此在處理 SELECT
子句時,別名 FirstLetter
還不存在。 Oracle 和 SQL Server 等資料庫嚴格遵守此順序,防止在 GROUP BY
.SELECT
中使用 GROUP BY
子句中的別名
中使用別名的擴充。 這種非標準行為並不普遍一致,因此驗證與特定資料庫系統的兼容性至關重要。 為了獲得可靠、可移植的 SQL,請始終使用 GROUP BY
子句中的基礎表達式,而不是依賴別名。 GROUP BY
以上是為什麼不能在 SQL GROUP BY 子句中使用列別名?的詳細內容。更多資訊請關注PHP中文網其他相關文章!