새소식

Programmers Coding Test/MySQL

[프로그래머스 59405] MySQL - Level1 상위 n개 레코드

  • -

 

상위 n개 레코드

 

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

 

프로그래머스

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

programmers.co.kr

 

 

1)  문제

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

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

ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는
각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.
동물 보호소에 가장 먼저 들어온 동물의 이름을 조회하는 SQL 문을 작성해주세요.

 

 

NAME TYPE NULLABLE
ANIMAL_ID VARCHAR(N) FALSE
ANIMAL_TYPE VARCHAR(N) FALSE
DATETIME DATETIME FALSE
INTAKE_CONDITION VARCHAR(N) FALSE
NAME VARCHAR(N) TRUE
SEX_UPON_INTAKE VARCHAR(N) FALSE

 

 

 

 

 

2)  예시

 

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

 

Animal Information

Animal Information

ANIMAL_ID ANIMAL_TYPE DATETIME INTAKE_CONDITION NAME SEX_UPON_INTAKE
A399552 Dog 2013-10-14 15:38:00 Normal Jack Neutered Male
A379998 Dog 2013-10-23 11:42:00 Normal Disciple Intact Male
A370852 Dog 2013-11-03 15:04:00 Normal Katie Spayed Female
A403564 Dog 2013-11-18 17:03:00 Normal Anna Spayed Female

 

이 중 가장 보호소에 먼저 들어온 동물은 Jack입니다. 따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

 

 

 

Animal Information

Animal Information

ANIMAL_ID ANIMAL_TYPE DATETIME INTAKE_CONDITION NAME SEX_UPON_INTAKE
A399552 Dog 2013-10-14 15:38:00 Normal Jack Neutered Male

 

 

 

3)  풀이

 

1. 모든 동물의 이름(NAME)를 조회합니다.

● SELECT NAME FROM ANIMAL_INS

 

2. 동물이 보호소에 들어온 순서대로 정렬합니다.

● ORDER BY DATETIME

 

3. 최상단에 있는 1개의 정보로 제한합니다. (가장 먼저 온 동물)

● LIMIT 1

 

 

 

 

 

4)  코드

 

SELECT NAME FROM ANIMAL_INS ORDER BY DATETIME LIMIT 1;

 

 

 

※ 참고  '2번째 및 3번째로 온 동물을 찾아라' 하는 코드

SELECT NAME FROM ANIMAL_INS ORDER BY DATETIME LIMIT 2 OFFSET 1;
// OFFSET으로 LIMIT의 시작점을 1번째 동물로 해서, 2번째 동물부터 2마리의 동물을 제한
// 즉, 2번째 및 3번째 동물이 출력됨

 

 

 

 

Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.