일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- select
- SQL
- array.slice()
- 역행자
- 코딩공부
- MySQL
- 개발자_조이킴
- for문
- 재귀함수
- 알고리즘
- 정규표현식
- 자바스크립트
- Programmers
- Algorithms
- 배열
- 코플릿
- Hackerrank
- JavaScript
- array.push()
- array
- join
- node.js
- Where
- 블록체인
- 코딩테스트
- 코드스테이츠
- 최강의 인생
- 프로그래머스
- 개발자의 책장
- Developer_JoyKim
Archives
- Today
- Total
CodingSpace
[프로그래머스/SQL] 입양 시각 구하기(1) (feat. GROUP BY, DATETIME변환) 본문
Problem. 입양 시각 구하기(1)
Link.
https://programmers.co.kr/learn/courses/30/lessons/59412
Description.
ANIMAL_OUTS 테이블은 동물 보호소에 입양을 보낸 동물의 정보를 담은 테이블입니다.
ANIMAL_OUTS 테이블 구조는 다음과 같습니다.
- ANIMAL_ID: 동물의 아이디
- ANIMAL_TYPE: 생물 종
- DATETIME: 입양일
- NAME: 이름
- SEX_UPON_INTAKE: 성별 및 중성화 여부
09:00 ~ 19:59까지, 각 시간대별로 입양이 몇 건이나 발생했는지 조회하는 SQL문을 작성해주세요.
※ 결과는 시간대 순으로 정렬합니다.
Key Point.
GROUP BY는 데이터를 특정 컬럼을 기준으로 그룹화하는 명렁어이다.
일반적으로 GROUP BY는 유형별로 개수를 알고 싶을 때 사용되며, 이때 COUNT와 함께 사용된다.
DATETIME 타입은 데이터타입 중 하나로 YYYY-MM-DD hh:mm:ss의 형식을 가진다.
문제처럼 시간(hh)만을 필요하는 경우가 있다면 어떻게 해야할까?
아래 예시처럼 DATETIME 타입은 사용자가 원하는 유형으로 변경할 수 있다.
본 문제에서는 시간 데이터만 필요하기 때문에 HOUR(DATETIME)을 사용해 시간에 해당하는 정보만 추출해 사용했다.
- YEAR(DATETIME): 년 정보만 추출, 예) 2022-03-09 13:10:00 → 2022
- MONTH(DATETIME): 월 정보만 추출, 예) 2022-03-09 13:10:00 → 3
- DAY(DATETIME): 일 정보만 추출, 예) 2022-03-09 13:10:00 → 9
- HOUR(DATETIME): 시간 정보만 추출, 예) 2022-03-09 13:10:00 → 13
- MINUTE(DATETIME): 분 정보만 추출, 예) 2022-03-09 13:10:00 → 10
- SECOND(DATETIME): 초 정보만 추출, 예) 2022-03-09 13:10:00 → 0
My Answer.
SELECT HOUR(DATETIME), COUNT(*) AS COUNT
FROM ANIMAL_OUTS
WHERE HOUR(DATETIME) >= 9
AND HOUR(DATETIME) < 20
GROUP BY HOUR(DATETIME)
ORDER BY HOUR(DATETIME) ASC
'프로그래머스 > SQL 고득점 Kit' 카테고리의 다른 글
[프로그래머스/SQL] 오랜 기간 보호한 동물(1) (feat. LEFT JOIN, LIMIT) (0) | 2022.03.11 |
---|---|
[프로그래머스/SQL] 있었는데요 없었습니다 (feat. JOIN, LEFT JOIN, RIGHT JOIN) (0) | 2022.03.10 |
[프로그래머스/SQL] 동명 동물 수 찾기 (feat. GROUP BY, HAVING) (0) | 2022.03.08 |
[프로그래머스/SQL] 고양이와 개는 몇 마리 있을까 (feat. GROUP BY) (0) | 2022.03.07 |
[프로그래머스/SQL] SQL 모든 레코드 조회하기 (feat. SELECT, ORDER BY) (0) | 2022.03.04 |
Comments