>데이터 베이스 >MySQL 튜토리얼 >SQL에서 '하위 쿼리가 2개 이상의 행을 반환합니다.' 오류를 어떻게 해결할 수 있습니까?

SQL에서 '하위 쿼리가 2개 이상의 행을 반환합니다.' 오류를 어떻게 해결할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-03 14:16:19891검색

How Can I Fix the

"하위 쿼리가 1개 이상의 행을 반환함" 오류 극복

여러 하위 쿼리 값으로 기준 설정

"하위 쿼리가 1개 이상의 행을 반환함" 발생 하위 쿼리 결과를 기반으로 기준을 설정하려고 할 때 " 오류가 발생하면 실망스러울 수 있습니다. 이 오류는 하위 쿼리가 여러 행을 반환하지만 기본 쿼리에서는 하나만 필요한 경우에 발생합니다.

이 문제를 해결하려면 항등 연산자(=)와 IN 연산자의 차이점을 이해하는 것이 중요합니다. 항등 연산자는 두 값만 비교할 수 있으며 하위 쿼리가 단일 값을 반환할 것으로 예상합니다. 반면에 IN 연산자를 사용하면 하나의 값을 여러 값 또는 하위 쿼리에서 반환된 값 집합과 비교할 수 있습니다.

IN 연산자 사용

하위 쿼리가 여러 행을 반환하는 경우, IN 연산자를 활용하여 기본 쿼리 값을 해당 여러 값과 비교해야 합니다. 구문은 다음과 같습니다.

SELECT *
FROM table
WHERE id IN (subquery)

이 예에서 하위 쿼리는 여러 행을 반환하고 기본 쿼리는 id 열이 해당 행 값과 일치하는지 확인합니다.

예 사용법

다음 시나리오를 고려하십시오.

  • 쿼리 1: SELECT id FROM table1은 값 1, 2, 3을 포함하는 여러 행을 반환합니다.
  • 쿼리 2: SELECT * FROM table2 WHERE id = (SELECT id FROM table1)은 하위 쿼리가 여러 행을 반환하므로 오류가 발생합니다.

이 오류를 해결하려면 IN을 사용하도록 쿼리 2를 수정하세요. 연산자:

SELECT * 
FROM table2 
WHERE id IN (SELECT id FROM table1)

이제 쿼리 2는 id 열이 하위 쿼리에서 반환된 값과 일치하는 table2에서 레코드를 올바르게 검색합니다.

결론

이해 하위 쿼리를 사용할 때는 항등 연산자와 IN 연산자를 구별하는 것이 필수적입니다. IN 연산자를 사용하면 "하위 쿼리가 1개 이상의 행을 반환합니다." 오류를 극복하고 하위 쿼리에서 얻은 여러 값을 기반으로 기준을 효과적으로 설정할 수 있습니다.

위 내용은 SQL에서 '하위 쿼리가 2개 이상의 행을 반환합니다.' 오류를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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