Notice
Recent Posts
Recent Comments
Link
«   2026/04   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30
Archives
Today
Total
관리 메뉴

yonny

[SQL] 오랜 기간 보호한 동물(1) (프로그래머스/LEVEL3) 본문

SQL/Programmers

[SQL] 오랜 기간 보호한 동물(1) (프로그래머스/LEVEL3)

yonny00 2023. 7. 26. 14:07

문제 : 오랜 기간 보호한 동물(1) (Lv. 3)

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 설명

 

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. 

ANIMAL_INS 테이블 구조는 다음과 같으며, 

ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는

각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

 

ANIMAL_OUTS 테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. 

ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_IDANIMAL_TYPEDATETIMENAMESEX_UPON_OUTCOME는 각각

동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다. 

ANIMAL_OUTS 테이블의 ANIMAL_ID는 ANIMAL_INS의 ANIMAL_ID의 외래 키입니다.

 

 

[ 문제 ]

 

아직 입양을 못 간 동물 중, 가장 오래 보호소에 있었던 동물 3마리의 이름과

보호 시작일을 조회하는 SQL문을 작성해주세요.

이때 결과는 보호 시작일 순으로 조회해야 합니다.

 

[ 예시 ]

 

예를 들어, ANIMAL_INS 테이블과 ANIMAL_OUTS 테이블이 다음과 같다면

따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

 

[ 출력 결과 ]

2. 문제 풀이

SELECT I.NAME, I.DATETIME
    FROM ANIMAL_INS I
    LEFT JOIN ANIMAL_OUTS O
    ON I.ANIMAL_ID = O.ANIMAL_ID
    WHERE O.ANIMAL_ID IS NULL
    ORDER BY I.DATETIME
    LIMIT 3;

 

 [ 문제 요구사항 ]

 

해당 문제에서는 크게 네 가지 동작이 필요하다.

 

1. ANIMAL_INS와 ANIMAL_OUTS 테이블을 LEFT JOIN하기 (이때, 키는 ANIMAL_ID)

2. 아직 입양을 못 간 동물은 ANIMAL_OUTS에 정보가 없는 경우를 뜻하기 때문에 ANIMAL_ID 가 NULL인 경우로 필터링

3. 보호 시작일 순으로 정렬

4. LIMIT로 상위 3개만 출력