MySQL 오류 "피연산자는 1개의 열을 포함해야 합니다." 해결 방법
이 글에서는 MySQL 쿼리에서 발생하는 "피연산자는 1개의 열을 포함해야 합니다." 오류를 해결합니다. 이 오류는 일반적으로 하위 쿼리가 여러 열을 반환하지만 외부 쿼리에서는 단일 열만 예상하는 경우에 발생합니다.
오해:
"피연산자는 1개의 열을 포함해야 합니다." 오류는 피연산자(여기서는 하위 쿼리)가 단일 열을 반환할 것으로 예상했지만 실제로는 여러 열을 반환하여 열 번호가 일치하지 않음을 나타냅니다.
해결된 문제:
이 문제는 하위 쿼리가 단일 열만 반환하도록 쿼리를 수정하여 해결할 수 있습니다. 두 가지 주요 방법이 있습니다:
1. JOIN 사용:
하위 쿼리를 사용하지 말고 JOIN
을 직접 사용하여 users
열의 posts
테이블과 posted_by
테이블을 조인하세요. 이 방법은 users
테이블에서 특정 열을 선택할 때 더 유연합니다.
<code class="language-sql">SELECT topics.id, topics.name, topics.post_count, topics.view_count, COUNT(posts.solved_post) AS solved_post, users.username AS posted_by, users.id AS posted_by_id FROM topics LEFT OUTER JOIN posts ON posts.topic_id = topics.id LEFT OUTER JOIN users ON users.id = posts.posted_by WHERE topics.cat_id = :cat GROUP BY topics.id</code>
2. 하위 쿼리에서 단일 열을 선택합니다.
또는 GROUP BY
절을 사용하여 단일 열만 반환하도록 하위 쿼리를 수정할 수도 있습니다. 그러나 이 방법을 사용하면 여러 사용자가 동일한 ID를 사용하는 경우 데이터가 손실될 수 있습니다.
<code class="language-sql">SELECT topics.id, topics.name, topics.post_count, topics.view_count, COUNT(posts.solved_post) AS solved_post, (SELECT users.username FROM users WHERE users.id = posts.posted_by GROUP BY users.id) AS posted_by FROM topics LEFT OUTER JOIN posts ON posts.topic_id = topics.id WHERE topics.cat_id = :cat GROUP BY topics.id</code>
선택하는 방법은 특정 요구 사항과 데이터 구조에 따라 다릅니다. JOIN을 사용하는 첫 번째 접근 방식은 일반적으로 더 효율적이고 명확한 솔루션입니다.
위 내용은 '피연산자는 1개의 열을 포함해야 합니다.' MySQL 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!