코딩테스트/SQL 문제

[프로그래머스] 298518 특정 물고기를 잡은 총 수 구하기 -SQL

glorypang 2025. 4. 28. 11:31
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