為什麼不能在 SQL GROUP BY 子句中使用列別名?
Jan 20, 2025 pm 09:07 PMSQL GROUP BY 子句與別名用法:了解限制
SQL 查詢處理遵循特定的順序,影響 GROUP BY
子句中別名的行為方式。本文闡明了這種行為及其根本原因。
讓我們檢查一個常見的查詢問題:
SELECT itemName AS ItemName, substring(itemName, 1,1) AS FirstLetter, Count(itemName) FROM table1 GROUP BY itemName, FirstLetter
登入後複製
此查詢有缺陷,因為 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中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器)
