집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 '하위 쿼리가 2개 이상의 행을 반환합니다.' 오류를 어떻게 해결할 수 있습니까?
"하위 쿼리가 1개 이상의 행을 반환함" 발생 하위 쿼리 결과를 기반으로 기준을 설정하려고 할 때 " 오류가 발생하면 실망스러울 수 있습니다. 이 오류는 하위 쿼리가 여러 행을 반환하지만 기본 쿼리에서는 하나만 필요한 경우에 발생합니다.
이 문제를 해결하려면 항등 연산자(=)와 IN 연산자의 차이점을 이해하는 것이 중요합니다. 항등 연산자는 두 값만 비교할 수 있으며 하위 쿼리가 단일 값을 반환할 것으로 예상합니다. 반면에 IN 연산자를 사용하면 하나의 값을 여러 값 또는 하위 쿼리에서 반환된 값 집합과 비교할 수 있습니다.
하위 쿼리가 여러 행을 반환하는 경우, IN 연산자를 활용하여 기본 쿼리 값을 해당 여러 값과 비교해야 합니다. 구문은 다음과 같습니다.
SELECT * FROM table WHERE id IN (subquery)
이 예에서 하위 쿼리는 여러 행을 반환하고 기본 쿼리는 id 열이 해당 행 값과 일치하는지 확인합니다.
다음 시나리오를 고려하십시오.
이 오류를 해결하려면 IN을 사용하도록 쿼리 2를 수정하세요. 연산자:
SELECT * FROM table2 WHERE id IN (SELECT id FROM table1)
이제 쿼리 2는 id 열이 하위 쿼리에서 반환된 값과 일치하는 table2에서 레코드를 올바르게 검색합니다.
이해 하위 쿼리를 사용할 때는 항등 연산자와 IN 연산자를 구별하는 것이 필수적입니다. IN 연산자를 사용하면 "하위 쿼리가 1개 이상의 행을 반환합니다." 오류를 극복하고 하위 쿼리에서 얻은 여러 값을 기반으로 기준을 효과적으로 설정할 수 있습니다.
위 내용은 SQL에서 '하위 쿼리가 2개 이상의 행을 반환합니다.' 오류를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!