>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 다중 필드 검색을 위해 SQL의 INTERSECT 기능을 복제하는 방법은 무엇입니까?

MySQL에서 다중 필드 검색을 위해 SQL의 INTERSECT 기능을 복제하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-05 20:53:47229검색

How to Replicate SQL's INTERSECT Functionality for Multiple Field Searches in MySQL?

다중 필드 검색을 위한 INTERSECT에 해당하는 MySQL

SQL에서 INTERSECT 연산자는 두 개 이상의 SELECT 문을 결합하여 해당하는 행만 반환합니다. 모든 조건을 만족합니다. 한 사용자는 최근 MySQL에서 INTERSECT를 사용하여 다중 필드 검색을 수행하는 데 어려움을 겪었습니다.

쿼리

다음 쿼리는 MySQL에서 'id' 필드를 검색하는 것을 목표로 했습니다. 'firstname'과 'lastname' 모두에 대해 'data' 테이블의 특정 값과 일치하는 행에 대한 'records' 테이블 fields:

SELECT records.id 
FROM records, data 
WHERE data.id = records.firstname 
AND data.value = "john"
INTERSECT
SELECT records.id 
FROM records, data 
WHERE data.id = records.lastname 
AND data.value = "smith"

MySQL Alternative

안타깝게도 MySQL은 INTERSECT 연산자를 지원하지 않습니다. 그러나 동일한 결과를 얻는 데는 여러 가지 대체 방법이 있습니다.

내부 조인

한 가지 접근 방식은 일치하는 모든 행을 반환하는 내부 조인을 사용하는 것입니다. 두 테이블의 값:

SELECT DISTINCT records.id 
FROM records
INNER JOIN data d1 on d1.id = records.firstname AND d1.value = "john"
INNER JOIN data d2 on d2.id = records.lastname AND d2.value = "smith"

IN 절

또 다른 대안은 하위 쿼리에 값이 존재하는지 테스트하는 IN 절을 사용하는 것입니다.

SELECT DISTINCT records.id 
FROM records
WHERE records.firstname IN (
    select id from data where value = 'john'
) 
AND records.lastname IN (
    select id from data where value = 'smith'
)

이러한 MySQL 호환 대안은 여러 필드를 수행하기 위한 효과적인 솔루션을 제공합니다. 높은 수준의 유연성과 성능을 제공합니다.

위 내용은 MySQL에서 다중 필드 검색을 위해 SQL의 INTERSECT 기능을 복제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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