> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 'INTERSECT' 기능을 어떻게 복제할 수 있나요?

MySQL의 'INTERSECT' 기능을 어떻게 복제할 수 있나요?

Linda Hamilton
풀어 주다: 2024-12-22 12:58:36
원래의
813명이 탐색했습니다.

How Can I Replicate MySQL's `INTERSECT` Functionality?

MySQL Intersect에 해당하는 항목 찾기

SQL에서 INTERSECT 연산자는 지정된 두 쿼리 모두에 나타나는 고유한 값을 검색합니다. 그러나 MySQL은 기본적으로 INTERSECT를 지원하지 않습니다.

MySQL의 대안

MySQL에서 비슷한 결과를 얻으려면 다음을 사용할 수 있습니다.

  • INNER JOIN: 열당 값은 두 테이블 모두에서 일치하지만 중복은 반환되었습니다.
  • WHERE ... IN: 두 번째 테이블에도 존재하는 첫 번째 테이블 내 고유 값을 선택합니다.

이를 활용하는 다른 데이터베이스 관리 시스템에서 다음 쿼리를 고려하십시오. INTERSECT:

(select * from emovis_reporting where (id=3 and cut_name= '全プロセス' and cut_name='恐慌') ) 
intersect
( select * from emovis_reporting where (id=3) and ( cut_name='全プロセス' or cut_name='恐慌') )
로그인 후 복사

INNER JOIN을 사용하는 MySQL 대안:

SELECT DISTINCT * 
FROM emovis_reporting e1
INNER JOIN emovis_reporting e2 
ON (e1.id = e2.id) AND (e1.cut_name = e2.cut_name)
WHERE e1.id = 3 AND (e1.cut_name = '全プロセス' OR e1.cut_name = '恐慌');
로그인 후 복사

WHERE ... IN을 사용하는 MySQL 대안 IN:

SELECT DISTINCT * 
FROM emovis_reporting
WHERE (id = 3) AND (cut_name IN ('全プロセス', '恐慌'));
로그인 후 복사

이러한 MySQL 대안은 다음을 충족하는 고유한 값을 반환합니다. 두 하위 쿼리 모두에 지정된 조건. 그러나 id 열이 이 특정 쿼리에 포함되어 중복 항목이 반환되는 것을 방지한다는 점에 유의하는 것이 중요합니다. 고유 식별자가 없는 쿼리의 경우 고유한 결과를 보장하려면 외부 쿼리에서 DISTINCT를 사용해야 할 수도 있습니다.

위 내용은 MySQL의 'INTERSECT' 기능을 어떻게 복제할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿