>데이터 베이스 >MySQL 튜토리얼 >'피연산자는 1개의 열을 포함해야 합니다.' MySQL 오류를 수정하는 방법은 무엇입니까?

'피연산자는 1개의 열을 포함해야 합니다.' MySQL 오류를 수정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-12 15:27:43843검색

How to Fix the

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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