首頁 >資料庫 >mysql教程 >為什麼在 MySQL 查詢中混合 JOIN 和逗號會導致「未知列」錯誤?

為什麼在 MySQL 查詢中混合 JOIN 和逗號會導致「未知列」錯誤?

Barbara Streisand
Barbara Streisand原創
2025-01-09 10:46:49423瀏覽

Why Does Mixing JOINs and Commas in MySQL Queries Cause

MySQL 查詢中混合使用 JOIN 和逗號導致錯誤

問題描述

執行下列 MySQL 查詢時:

<code class="language-sql">SELECT m.*, t.*
FROM memebers as m, telephone as t
INNER JOIN memeberFunctions as mf ON m.id = mf.memeber
INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber
WHERE mf.function = 32</code>

會遇到以下錯誤:

<code>#1054 - Unknown column 'm.id' in 'on clause'</code>

儘管該列存在,但查詢仍然失敗。此錯誤發生在查詢中同時使用 ANSI 1992 JOIN 語法和逗號時。

根據 MySQL 文檔,應避免混合使用 JOIN 和逗號。若要解決此問題,請將逗號替換為適當的 JOIN 運算子(CROSS、INNER、LEFT)。

使用 INNER JOIN 的更新後的查詢如下:

<code class="language-sql">SELECT m.*, t.*
FROM memebers as m
INNER JOIN telephone as t ON <join condition>
INNER JOIN memeberFunctions as mf ON m.id = mf.memeber AND mf.function = 32
INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber</code>

請注意,應指定 mt 之間的連接條件,以避免笛卡爾積。

附加說明

為提高清晰度和效率,應使用 JOIN 運算子而不是逗號。逗號表示 CROSS JOIN,這可能會導致意外行為,尤其是在組合多個表時。透過使用明確的 JOIN 運算符,您可以定義表之間的特定關係,從而確保獲得所需的結果。

以上是為什麼在 MySQL 查詢中混合 JOIN 和逗號會導致「未知列」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn