> 데이터 베이스 > MySQL 튜토리얼 > 내 SQL 하위 쿼리에서 '선택 목록에는 하나의 식만 지정할 수 있습니다.' 오류가 발생하는 이유는 무엇입니까?

내 SQL 하위 쿼리에서 '선택 목록에는 하나의 식만 지정할 수 있습니다.' 오류가 발생하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-11 13:36:42
원래의
360명이 탐색했습니다.

Why Does My SQL Subquery Produce

SQL 하위 쿼리 오류 문제 해결: "단 하나의 표현식만 지정할 수 있습니다..."

"EXISTS에 하위 쿼리가 도입되지 않은 경우 선택 목록에 하나의 표현식만 지정할 수 있습니다."라는 오류는 SQL 쿼리가 IN 절 내에서 하위 쿼리를 사용하고 하위 쿼리가 여러 열을 반환하려고 시도할 때 발생합니다. . IN 연산자는 비교를 위해 단일 열만 허용합니다.

문제가 있는 쿼리를 살펴보겠습니다.

<code class="language-sql">select count(distinct dNum)
from myDB.dbo.AQ
where A_ID in 
  (SELECT DISTINCT TOP (0.1) PERCENT A_ID, 
            COUNT(DISTINCT dNum) AS ud 
 FROM         myDB.dbo.AQ
 WHERE     M > 1 and B = 0 
 GROUP BY A_ID ORDER BY ud DESC)</code>
로그인 후 복사

내부 SELECT 문이 A_IDCOUNT(DISTINCT dNum) AS ud을 모두 잘못 반환합니다. 이는 IN.

과 함께 사용되는 하위 쿼리 규칙을 위반합니다.

수정된 쿼리:

해결 방법은 A_ID 열만 반환하도록 하위 쿼리를 재구성하는 것입니다.

<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>
로그인 후 복사

이 수정된 쿼리는 이제 하위 쿼리에서 A_ID만 올바르게 선택하여 오류를 해결합니다. COUNT(DISTINCT dNum)에 의한 정렬은 하위 쿼리 자체 내에서 처리되어 A_ID 값의 상위 10%(COUNT(DISTINCT dNum)를 기준으로 선택됨

)를 보장합니다.

위 내용은 내 SQL 하위 쿼리에서 '선택 목록에는 하나의 식만 지정할 수 있습니다.' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿