>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 PostgreSQL의 INTERSECT 기능을 어떻게 복제할 수 있습니까?

MySQL에서 PostgreSQL의 INTERSECT 기능을 어떻게 복제할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-28 02:33:14604검색

How Can I Replicate PostgreSQL's INTERSECT Functionality in MySQL?

MySQL에서는 PostgreSQL INTERSECT와 동일

MySQL에서는 INTERSECT 연산자가 지원되지 않습니다. 그러나 유사한 결과를 얻기 위한 몇 가지 대체 접근 방식이 있습니다.

예를 들어, 특정 기준을 충족하는 레코드를 여러 필드에서 검색할 때 내부 조인을 사용할 수 있습니다. 다음 쿼리는 "data" 테이블의 일치하는 행이 있는 "records" 테이블의 행을 필터링합니다. 여기서 "john" 및 "smith"는 각각 "firstname" 및 "lastname" 필드의 값에 해당합니다.

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 절입니다:

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에서 PostgreSQL의 INTERSECT 기능을 어떻게 복제할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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