[programmers] 경기도에 위치한 식품창고 목록 출력하기 - MySQL

FOOD_WAREHOUSE 테이블에서 경기도에 위치한 창고의 정보를 조회하는 SQL문을 작성하는 문제로, 주소가 '경기도%'인 창고의 ID, 이름, 주소, 냉동시설 여부를 조회하며, 냉동시설 여부가 NULL인 경우 'N'으로 출력하고 결과는 창고 ID를 기준으로 오름차순 정렬한다. 이 문제를 통해 like 연산자와 % 와일드카드를 활용하는 법을 이해할 수 있다.
Jan 24, 2024
[programmers] 경기도에 위치한 식품창고 목록 출력하기 - MySQL

문제 설명

다음은 식품창고의 정보를 담은 FOOD_WAREHOUSE 테이블입니다. FOOD_WAREHOUSE 테이블은 다음과 같으며 WAREHOUSE_IDWAREHOUSE_NAMEADDRESSTLNOFREEZER_YN는 창고 ID, 창고 이름, 창고 주소, 전화번호, 냉동시설 여부를 의미합니다.
Column name
Type
Nullable
WAREHOUSE_ID
VARCHAR(10)
FALSE
WAREHOUSE_NAME
VARCHAR(20)
FALSE
ADDRESS
VARCHAR(100)
TRUE
TLNO
VARCHAR(20)
TRUE
FREEZER_YN
VARCHAR(1)
TRUE

문제

FOOD_WAREHOUSE 테이블에서 경기도에 위치한 창고의 ID, 이름, 주소, 냉동시설 여부를 조회하는 SQL문을 작성해주세요. 이때 냉동시설 여부가 NULL인 경우, 'N'으로 출력시켜 주시고 결과는 창고 ID를 기준으로 오름차순 정렬해주세요.

예시

FOOD_WAREHOUSE 테이블이 다음과 같을 때
WAREHOUSE_ID
WAREHOUSE_NAME
ADDRESS
TLNO
FREEZER_YN
WH0001
창고_경기1
경기도 안산시 상록구 용담로 141
031-152-1332
Y
WH0002
창고_충북1
충청북도 진천군 진천읍 씨제이로 110
043-623-9900
Y
WH0003
창고_경기2
경기도 이천시 마장면 덕평로 811
031-221-7241
NULL
WH0004
창고_경기3
경기도 김포시 대곶면 율생중앙로205번길
031-671-1900
N
WH0005
창고_충남1
충청남도 천안시 동남구 광덕면 신덕리1길 9
041-876-5421
Y
SQL을 실행하면 다음과 같이 출력되어야 합니다.
WAREHOUSE_ID
WAREHOUSE_NAME
ADDRESS
FREEZER_YN
WH0001
창고_경기1
경기도 안산시 상록구 용담로 141
Y
WH0003
창고_경기2
경기도 이천시 마장면 덕평로 811
N
WH0004
창고_경기3
경기도 김포시 대곶면 율생중앙로205번길
N

solution.sql

SELECT WAREHOUSE_ID, WAREHOUSE_NAME, ADDRESS, IFNULL(FREEZER_YN, 'N') from FOOD_WAREHOUSE where address like '경기도%' order by WAREHOUSE_ID;
 

핵심 키워드

  • like 연산자를 통해 특정 키워드가 포함된 데이터를 검색할 수 있다.
  • 퍼센트 기호( % ) 와일드카드는 검색할 문자열 내에서 사용하면 개수에 상관없이 모든 문자를 의미한다.
 

결론!

해당 문제를 풀면서 like 연산자와 % 와일드카드를 활용하는 법을 이해할 수 있었다.
 
Share article

More articles

See more posts
RSSPowered by inblog