>데이터 베이스 >MySQL 튜토리얼 >SQL을 사용하여 다른 데이터베이스 테이블을 기반으로 한 데이터베이스 테이블에서 누락된 레코드를 어떻게 찾을 수 있습니까?

SQL을 사용하여 다른 데이터베이스 테이블을 기반으로 한 데이터베이스 테이블에서 누락된 레코드를 어떻게 찾을 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-25 10:58:11418검색

How Can I Find Missing Records in One Database Table Based on Another Using SQL?

"SELECT * WHERE NOT EXISTS"를 사용하여 누락된 레코드 식별

여러 데이터베이스로 작업할 때 하나의 데이터베이스에서 레코드를 식별해야 할 수도 있습니다. 다른 테이블에는 존재하지 않는 테이블입니다. 이는 "SELECT * WHERE NOT EXISTS" 쿼리를 사용하여 수행할 수 있습니다.

"employees" 테이블에 직원 세부 정보가 포함되고 "eotm_dyn" 테이블에 추가 직원 정보가 포함되는 시나리오에서는 이것이 적합해집니다. "eotm_dyn"에 해당 항목이 없는 직원을 확인합니다. 이를 수행하려면 다음과 같이 쿼리를 작성할 수 있습니다.

SELECT  *
FROM    employees e
WHERE   NOT EXISTS
        (
        SELECT  null
        FROM    eotm_dyn d
        WHERE   d.employeeID = e.id
        )

이 쿼리는 "NOT EXISTS"를 사용하여 "employeeID" 필드에서 "employees"와 "eotm_dyn" 테이블 사이에 왼쪽 조인을 수행합니다. 절을 사용하여 "eotm_dyn"에 일치하는 항목이 없는 "employees"의 모든 레코드를 필터링합니다. 결과는 "eotm_dyn" 테이블에 표시되지 않은 모든 직원의 목록입니다.

위 내용은 SQL을 사용하여 다른 데이터베이스 테이블을 기반으로 한 데이터베이스 테이블에서 누락된 레코드를 어떻게 찾을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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