없어진 기록 찾기

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

ANIMAL_OUTS 테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, NAME, SEX_UPON_OUTCOME는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다. ANIMAL_OUTS 테이블의 ANIMAL_ID는 ANIMAL_INS의 ANIMAL_ID의 외래 키입니다.

천재지변으로 인해 일부 데이터가 유실되었습니다. 입양을 간 기록은 있는데, 보호소에 들어온 기록이 없는 동물의 ID와 이름을 ID 순으로 조회하는 SQL문을 작성해주세요.

없어진 기록 찾기Lv.3

59042

https://school.programmers.co.kr/learn/courses/30/lessons/59042

해설

  • Name
    SELECT ANIMAL_OUTS.ANIMAL_ID, ANIMAL_OUTS.NAME
    Type
    Description

    ANIMAL_OUTS 테이블에서 ANIMAL_ID와 NAME 필드를 선택하여 결과로 반환합니다.

  • Name
    LEFT JOIN ANIMAL_INS ON ANIMAL_OUTS.ANIMAL_ID = ANIMAL_INS.ANIMAL_ID
    Type
    Description

    ANIMAL_OUTS 테이블을 ANIMAL_INS 테이블과 왼쪽 조인(Left Join)합니다. 여기서 조인 조건은 두 테이블의 ANIMAL_ID 필드가 같은 경우입니다.

  • Name
    WHERE ANIMAL_INS.ANIMAL_ID IS NULL
    Type
    Description

    ANIMAL_INS 테이블에서 일치하는 ANIMAL_ID가 없는 ANIMAL_OUTS 테이블의 레코드만을 필터링합니다. 즉, ANIMAL_OUTS 테이블에 있는 동물이 ANIMAL_INS 테이블에 없는 경우에 해당합니다. 천재지변으로 데이터가 누락됐기 때문에 없어야 합니다.

ANIMAL_OUTS 테이블에는 있지만 ANIMAL_INS 테이블에는 없는 동물의 ID와 이름을 반환합니다.

없어진 기록 찾기

SELECT
    ANIMAL_OUTS.ANIMAL_ID, ANIMAL_OUTS.NAME
FROM
    ANIMAL_OUTS
LEFT JOIN
    ANIMAL_INS
ON
    ANIMAL_OUTS.ANIMAL_ID = ANIMAL_INS.ANIMAL_ID
WHERE ANIMAL_INS.ANIMAL_ID IS NULL