MySQL 的非標準 GROUP BY
行為
MySQL 和其他 SQL 資料庫(如 Oracle 和 SQL Server)之間的一個關鍵區別在於它們處理 GROUP BY
子句的方式。 MySQL 允許 GROUP BY
查詢而不需要聚合函數,這是一個偏離標準 ANSI SQL 的函數。這項設計決策雖然提供了潛在的效能優勢和使用者便利性,但也引起了有關 SQL 標準合規性的批評。
MySQL 的理由:
MySQL 的開發人員認為這種靈活性提高了查詢效能和可用性。 透過允許在 GROUP BY
子句中選擇非聚合列,使用者可以避免使用額外的、可能不必要的聚合函數。 這簡化了查詢並且可以提高效率。
例如,以下查詢:
<code class="language-sql">SELECT X, Y FROM someTable GROUP BY X;</code>
在 MySQL 中,這會傳回唯一 X
值的列表,每個值與群組中的 任意 對應 Y
值配對。 當僅需要不同的 X
值時,無論與每個值關聯的特定 Y
資料如何,這都非常有用。
控制 MySQL 的行為:
雖然 MySQL 提供了這種寬鬆的解釋,但使用者可以透過設定 only_full_group_by
SQL 模式來強制執行嚴格的 ANSI SQL 合規性。啟用此模式後,GROUP BY
缺少聚合函數的查詢將產生錯誤。
摘要:
MySQL 靈活的GROUP BY
功能體現了優先考慮效能和易用性的設計理念。 然而,這偏離了 ANSI SQL 標準。 only_full_group_by
設定允許開發人員在這種便利性和嚴格的標準合規性之間進行選擇。
以上是MySQL 靈活的「GROUP BY」與標準 SQL 有何不同,為什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!