>데이터 베이스 >MySQL 튜토리얼 >내 MySQL 쿼리에서 'ON 절의 알 수 없는 열' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

내 MySQL 쿼리에서 'ON 절의 알 수 없는 열' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

DDD
DDD원래의
2025-01-13 07:04:41710검색

Why Does My MySQL Query Produce an

MySQL "ON 절의 알 수 없는 열" 오류: 종합적인 해결 방법

MySQL에서 "'ON 절'의 알 수 없는 열 'columnName'" 오류가 발생하면 당황스러울 수 있습니다. 이 오류는 조인 작업이 데이터베이스에서 찾을 수 없는 열을 참조할 때 발생합니다. 원인을 분석하고 해결책을 제시해보겠습니다.

오류는 일반적으로 조인 구문에 문제가 있음을 나타냅니다. 샘플 쿼리를 살펴보겠습니다.

<code class="language-sql">SELECT p.*,
    IF(COUNT(ms.PropertyID) > 0,1,0) AS Contacted,
    pm.MediaID,
    DATE_FORMAT(p.AvailableFrom, '%d %b %Y') AS 'AvailableFrom',
    AsText(pg.Geometry) AS Geometry
FROM property p, propertygeometry pg
    JOIN shortlist sl ON sl.PropertyID = p.id AND sl.MemberID = 384216
    LEFT JOIN message ms ON ms.PropertyID = p.id AND ms.SenderID = 384216
    LEFT JOIN property_media pm ON pm.PropertyID = p.id AND pm.IsPrimary = 1
WHERE p.paused = 0
    AND p.PropertyGeometryID = pg.id
GROUP BY p.id</code>

여기서 핵심 문제는 조인 스타일의 혼합입니다. 쉼표로 구분된 조인(property p, propertygeometry pg)은 이전 ANSI-89 스타일이고 후속 조인은 최신 ANSI-92 JOIN 구문을 사용합니다. 이러한 조인 스타일의 불일치로 인해 예기치 않은 동작과 오류가 발생합니다.

ANSI-89(쉼표) 대 ANSI-92(JOIN) 조인

MySQL은 ANSI-89(쉼표 스타일) 및 ANSI-92(JOIN 키워드) 조인을 모두 지원합니다. 그러나 우선순위가 다르기 때문에 혼합 사용이 문제가 됩니다. JOIN 키워드의 우선 순위가 높기 때문에 쉼표 조인과 결합하면 데이터베이스가 테이블 간의 관계를 잘못 해석하게 됩니다.

해결책: 일관된 ANSI-92 조인

이 문제를 해결하려면 쿼리의 모든 조인에 대해 ANSI-92 JOIN 구문을 일관되게 사용하십시오. 수정된 버전은 다음과 같습니다.

<code class="language-sql">SELECT p.*,
    IF(COUNT(ms.PropertyID) > 0,1,0) AS Contacted,
    pm.MediaID,
    DATE_FORMAT(p.AvailableFrom, '%d %b %Y') AS 'AvailableFrom',
    AsText(pg.Geometry) AS Geometry
FROM property p
JOIN propertygeometry pg ON p.PropertyGeometryID = pg.id
JOIN shortlist sl ON sl.PropertyID = p.id AND sl.MemberID = 384216
LEFT JOIN message ms ON ms.PropertyID = p.id AND ms.SenderID = 384216
LEFT JOIN property_media pm ON pm.PropertyID = p.id AND pm.IsPrimary = 1
WHERE p.paused = 0
GROUP BY p.id</code>

균일한 JOIN 구문을 사용하면 모호성을 제거하고 데이터베이스가 조인 조건을 올바르게 해석하여 "ON 절의 알 수 없는 열" 오류를 해결할 수 있습니다. 이 접근 방식을 통해 더욱 명확하고 유지 관리가 용이한 SQL 코드를 얻을 수 있습니다.

위 내용은 내 MySQL 쿼리에서 'ON 절의 알 수 없는 열' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.