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中文网其他相关文章!