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>
請注意,應指定 m
和 t
之間的連接條件,以避免笛卡爾積。
附加說明
為提高清晰度和效率,應使用 JOIN 運算子而不是逗號。逗號表示 CROSS JOIN,這可能會導致意外行為,尤其是在組合多個表時。透過使用明確的 JOIN 運算符,您可以定義表之間的特定關係,從而確保獲得所需的結果。
以上是為什麼在 MySQL 查詢中混合 JOIN 和逗號會導致「未知列」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!