프로그래머스/프로그래머스 - SQL

[sql] 찾아 수 구하는 문제들

메타듀 2023. 2. 24. 15:46
728x90
반응형

고양이와 개는 몇 마리 있을까

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

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

동물 보호소에 들어온 동물 중 고양이와 개가 각각 몇 마리인지 조회하는 SQL문을 작성해주세요. 이때 고양이를 개보다 먼저 조회해주세요.

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

ANIMAL_ID    ANIMAL_TYPE    DATETIME                INTAKE_CONDITION    NAME    SEX_UPON_INTAKE
A373219        Cat            2014-07-29 11:43:00        Normal                Ella    Spayed Female
A377750        Dog            2017-10-25 17:17:00        Normal                Lucy    Spayed Female    
A354540        Cat    2        014-12-11 11:48:00        Normal                Tux        Neutered Male

고양이는 2마리, 개는 1마리 들어왔습니다. 따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

ANIMAL_TYPE    count
Cat            2
Dog            1

[sql문]

SELECT ANIMAL_TYPE, count(ANIMAL_TYPE) as count
from ANIMAL_INS
where ANIMAL_TYPE='Cat' or  ANIMAL_TYPE='Dog'
group by ANIMAL_TYPE
order by ANIMAL_TYPE;

 

 

 

동물 수 구하기

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

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

동물 보호소에 동물이 몇 마리 들어왔는지 조회하는 SQL 문을 작성해주세요.

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

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

동물 보호소에 들어온 동물은 4마리입니다. 따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

count
4

[sql문]

SELECT count(ANIMAL_ID)
from ANIMAL_INS;

 

 

 

최솟값 구하기

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

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

동물 보호소에 가장 먼저 들어온 동물은 언제 들어왔는지 조회하는 SQL 문을 작성해주세요.

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

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이고, Jack은 2013-10-14 15:38:00에 들어왔습니다. 따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

시간
2013-10-14 15:38:00

[sql문]

SELECT min(DATETIME)
from ANIMAL_INS;
반응형