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