728x90
반응형
SMALL
📌 문제 정보
- 출처: 문제 링크
- 난이도: ⭐
- 문제 유형: SELECT
- 사용 언어: SQL
🔍 문제 설명
낚시앱에서 사용하는 FISH_INFO 테이블은 잡은 물고기들의 정보를 담고 있습니다. FISH_INFO 테이블의 구조는 다음과 같으며 ID, FISH_TYPE, LENGTH, TIME은 각각 잡은 물고기의 ID, 물고기의 종류(숫자), 잡은 물고기의 길이(cm), 물고기를 잡은 날짜를 나타냅니다.
단, 잡은 물고기의 길이가 10cm 이하일 경우에는 LENGTH 가 NULL 이며, LENGTH 에 NULL 만 있는 경우는 없습니다.
FISH_NAME_INFO 테이블은 물고기의 이름에 대한 정보를 담고 있습니다. FISH_NAME_INFO 테이블의 구조는 다음과 같으며, FISH_TYPE, FISH_NAME 은 각각 물고기의 종류(숫자), 물고기의 이름(문자) 입니다.
FISH_INFO 테이블에서 잡은 BASS와 SNAPPER의 수를 출력하는 SQL 문을 작성해주세요.
컬럼명은 'FISH_COUNT`로 해주세요.
💡 풀이 노트
- `FISH_INFO` 테이블과 `FISH_NAME_INFO` 테이블을 `FISH_TYPE` 컬럼을 기준으로 `JOIN`해서 연결
- `WHERE IN` 구문을 사용해서 `FISH_NAME`이 'BASS' 또는 'SNAPPER'인 경우만 골라냄
- `IN`은 여러 개의 값을 한 번에 비교할 때 사용 (예: "BASS" 또는 "SNAPPER" 둘 중 하나인 경우)
- 조건에 맞는 물고기들을 대상으로 `COUNT(*)` 함수를 이용해 총 몇 마리인지 개수를 세어줌
🚀 코드 (SQL)
SELECT COUNT(*) AS `FISH_COUNT`
FROM FISH_INFO A JOIN FISH_NAME_INFO B
ON A.FISH_TYPE = B.FISH_TYPE
WHERE FISH_NAME IN ('BASS', 'SNAPPER')
🖥 실행 결과
출력
FISH_COUNT
7
📌 깃허브 코드 저장소: https://github.com/glorypang/CodingTest
728x90
반응형
LIST