집 >데이터 베이스 >MySQL 튜토리얼 >내 SQL 하위 쿼리가 '하위 쿼리가 EXISTS로 도입되지 않은 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다'를 반환하는 이유는 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!