코딩 테스트 일기 - 04

윤수빈·2024년 7월 22일
0

1. SQL

1번 문제

: 있었는데요 없었습니다

문제 설명

: 관리자의 실수로 일부 동물의 입양일이 잘못 입력되었습니다. 보호 시작일보다 입양일이 더 빠른 동물의 아이디와 이름을 조회하는 SQL문을 작성해주세요. 이때 결과는 보호 시작일이 빠른 순으로 조회해야합니다.

문제 풀이

  1. 보호 시작일과 입양일이 둘 다 있어야 하므로 inner join 으로 묶음
  2. 보호 시작일보다 입양일이 빠른 것이기 때문에 대소비교 사용
  3. 보호 시작일이 빠른 순으로 정렬
  4. 동물의 아이디와 이름을 조회

구현 코드

SELECT ano.ANIMAL_ID, ani.NAME
from ANIMAL_OUTS ano inner join ANIMAL_INS ani on ano.ANIMAL_ID = ani.ANIMAL_ID
where ano.DATETIME < ani.DATETIME
order by ani.DATETIME

2번 문제

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

문제 설명

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

문제 풀이

  1. 보호 시작일과 입양일이 둘 다 있어야 하므로 inner join 으로 묶음
  2. 기간 차이를 계산하는 TIMESTAMPDIFF() 사용
  3. 가장 길었던 동물이므로 내림차순 정렬
  4. 동물 2마리만 조회
  5. 기간 차이를 서브쿼리로 사용함
  6. 동물의 아이디와 이름을 조회

구현 코드

select ANIMAL_ID, NAME
from
(SELECT ano.ANIMAL_ID, ano.NAME, TIMESTAMPDIFF(minute, ani.DATETIME, ano.DATETIME) as min_diff
from ANIMAL_OUTS ano inner join ANIMAL_INS ani on ano.ANIMAL_ID = ani.ANIMAL_ID) a
order by min_diff desc
limit 2

3번 문제

: 보호소에서 중성화한 동물

문제 설명

: 보호소에서 중성화 수술을 거친 동물 정보를 알아보려 합니다. 보호소에 들어올 당시에는 중성화되지 않았지만, 보호소를 나갈 당시에는 중성화된 동물의 아이디와 생물 종, 이름을 조회하는 아이디 순으로 조회하는 SQL 문을 작성해주세요.

문제 풀이

  1. 보호 시작일과 입양일이 둘 다 있어야 하므로 inner join 으로 묶음
  2. 보호소 기록 중성화 상태와 입양 기록 중성화 상태를 비교
  3. 동물 아이디 오름차순 정렬
  4. 동물의 아이디와 생물 종, 이름을 조회

구현 코드

SELECT ano.ANIMAL_ID, ano.ANIMAL_TYPE, ano.NAME
from ANIMAL_OUTS ano inner join ANIMAL_INS ani on ano.ANIMAL_ID = ani.ANIMAL_ID
where ani.SEX_UPON_INTAKE <> ano.SEX_UPON_OUTCOME
order by 1
profile
정의로운 사회운동가

0개의 댓글