오랜 기간 보호한 동물(2)

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의 외래 키입니다.

입양을 간 동물 중, 보호 기간이 가장 길었던 동물 두 마리의 아이디와 이름을 조회하는 SQL문을 작성해주세요. 이때 결과는 보호 기간이 긴 순으로 조회해야 합니다.

오랜 기간 보호한 동물(2)Lv.3

59411

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

해설

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

    ANIMAL_INS 테이블에서 ANIMAL_ID와 NAME 열을 선택하라는 의미입니다. 이것은 결과로 동물의 ID와 이름을 가져올 것을 나타냅니다.

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

    ANIMAL_INS 테이블과 ANIMAL_OUTS 테이블을 ANIMAL_ID 열을 기준으로 조인하라는 의미입니다. 이렇게 하면 두 테이블 간에 ANIMAL_ID가 일치하는 경우에만 결과에 포함됩니다.

  • Name
    ORDER BY DATEDIFF(ANIMAL_OUTS.DATETIME, ANIMAL_INS.DATETIME) DESC
    Type
    Description

    ANIMAL_OUTS 테이블의 DATETIME과 ANIMAL_INS 테이블의 DATETIME 간의 차이를 계산하고, 그 차이를 내림차순으로 정렬하라는 의미입니다.

    • 주의 사항으로는 반드시 ANIMAL_OUTS.DATETIME에서 ANIMAL_INS.DATETIME을 비교해야 합니다. 보호 기간이 가장 길었던 것을 찾아야하기 때문에
  • Name
    LIMIT 2
    Type
    Description

    상위 2개의 레코드만 가져오라는 의미입니다.

오랜 기간 보호한 동물(2)

SELECT
    ANIMAL_INS.ANIMAL_ID, ANIMAL_INS.NAME
FROM
    ANIMAL_INS
LEFT JOIN
    ANIMAL_OUTS
ON
    ANIMAL_INS.ANIMAL_ID = ANIMAL_OUTS.ANIMAL_ID
ORDER BY
    DATEDIFF(ANIMAL_OUTS.DATETIME, ANIMAL_INS.DATETIME) DESC
LIMIT 2;