>데이터 베이스 >MySQL 튜토리얼 >내 SQL 하위 쿼리가 '하위 쿼리가 EXISTS로 도입되지 않은 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다'를 반환하는 이유는 무엇입니까?

내 SQL 하위 쿼리가 '하위 쿼리가 EXISTS로 도입되지 않은 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다'를 반환하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-11 13:32:44549검색

Why Does My SQL Subquery Return

SQL 하위 쿼리 선택 목록 제한

"하위 쿼리가 EXISTS로 시작하지 않는 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다."라는 오류가 발생하면 하위 쿼리의 반환 값에 문제가 있음을 의미합니다. WHERE IN 절 내에 중첩된 하위 쿼리에서는 IN의 반대쪽과 비교하기 위해 하나의 열만 반환되도록 하는 것이 중요합니다.

처음에 제공된 쿼리에는 A_ID 및 COUNT(DISTINCT dNum)를 ud로 반환하는 하위 쿼리가 포함되어 있습니다. 그러나 WHERE IN 절에서 하위 쿼리는 기본 쿼리의 A_ID와 비교되는 단일 열만 반환할 수 있습니다. 이러한 제한이 존재하는 이유는 하위 쿼리의 기능이 기본 쿼리의 A_ID가 하위 쿼리 결과의 값과 일치하는지 확인하기 위해 값 목록을 반환하는 것이기 때문입니다.

이 문제를 해결하려면 A_ID 열만 반환하도록 하위 쿼리를 수정하세요. 이 열은 기본 쿼리의 WHERE IN 절에 있는 A_ID와 비교됩니다. 또한 ORDER 절에서 정렬을 사용하면 COUNT를 열로 반환하지 않고 하위 쿼리에서 행을 선택할 수 있습니다.

수정된 쿼리 예:

<code class="language-sql">SELECT COUNT(DISTINCT dNum)
FROM myDB.dbo.AQ
WHERE A_ID IN (
    SELECT DISTINCT TOP (0.1) PERCENT A_ID
    FROM myDB.dbo.AQ
    WHERE M > 1 AND B = 0
    GROUP BY A_ID
    ORDER BY COUNT(DISTINCT dNum) DESC
)</code>

이러한 변경 사항을 구현하면 쿼리는 WHERE IN 비교를 위해 단일 열을 반환하는 규칙을 준수하면서 원하는 결과를 올바르게 반환할 수 있습니다.

위 내용은 내 SQL 하위 쿼리가 '하위 쿼리가 EXISTS로 도입되지 않은 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다'를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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