[Programmers/Level 1~2] IS NULL(MySQL)
·
Programmers/Level 1~2
Level 1 경기도에 위치한 식품창고 목록 출력하기 IFNULL을 사용하여 냉동시설 여부가 없다면 'N'으로 출력하도록 하고, 주소가 경기도로 시작하는 식품창고만을 찾도록 한다. SELECT A.WAREHOUSE_ID, A.WAREHOUSE_NAME, A.ADDRESS, IFNULL(A.FREEZER_YN, 'N') AS FREEZER_YN FROM FOOD_WAREHOUSE A WHERE A.ADDRESS LIKE '경기도%' ORDER BY A.WAREHOUSE_ID ASC 이름이 없는 동물의 아이디 SELECT A.ANIMAL_ID FROM ANIMAL_INS A WHERE A.NAME IS NULL ORDER BY A.ANIMAL_ID ASC 이름이 있는 동물의 아이디 SELECT A.ANIMA..
[Programmers/Level 4] SELECT(MySQL)
·
Programmers/Level 4
Level 4 서울에 위치한 식당 목록 출력하기 식당의 아이디를 기준으로 Join하고 주소가 서울로 시작하는 식당들만을 아이디를 기준으로 그룹화한다. 리뷰 평균점수는 AVG로 구하고, ROUND로 소수점 셋째 자리에서 반올림한다. SELECT A.REST_ID, A.REST_NAME, A.FOOD_TYPE, A.FAVORITES AS FAVORITES, A.ADDRESS, ROUND(AVG(B.REVIEW_SCORE), 2) AS SCORE FROM REST_INFO A INNER JOIN REST_REVIEW B ON A.REST_ID = B.REST_ID GROUP BY A.REST_ID HAVING A.ADDRESS LIKE '서울%' ORDER BY SCORE DESC, A.FAVORITES DE..
[Programmers/Level 4] JOIN(MySQL)
·
Programmers/Level 4
Level 4 주문량이 많은 아이스크림들 조회하기 중복된 맛을 가진 아이스크림 주문 정보는 JULY 테이블에만 있으므로 JULY 테이블의 맛을 기준으로 FIRST_HALF 테이블의 데이터를 가져온다. 그리고 FLAVOR를 기준으로 그룹화한 후 총 주문량을 더한 다음 내림차순으로 정렬하고 LIMIT를 활용해 세 번째 데이터까지 출력한다. SELECT B.FLAVOR FROM JULY B INNER JOIN FIRST_HALF A ON A.FLAVOR = B.FLAVOR GROUP BY B.FLAVOR ORDER BY SUM(A.TOTAL_ORDER + B.TOTAL_ORDER) DESC LIMIT 3 특정 기간동안 대여 가능한 자동차들의 대여비용 구하기 먼저 3개의 테이블을 Join한다. 그리고 CAR_T..
[Programmers/Level 3] JOIN(MySQL)
·
Programmers/Level 3
Level 3 없어진 기록 찾기 OUTER JOIN을 사용하여 동물의 아이디를 기준으로 ANIMAL_OUTS 테이블에 ANIMAL_INS의 데이터를 가져온다. 그런데 ANIMAL_INS의 DATETIME이 존재하지 않는다면, 입양 기록은 있는데 보호소에 데려온 기록이 없다는 뜻이므로 해당하는 데이터의 동물 아이디와 이름을 아이디를 오름차순 정렬하여 리스트로 출력한다. SELECT B.ANIMAL_ID, B.NAME FROM ANIMAL_INS A RIGHT OUTER JOIN ANIMAL_OUTS B ON A.ANIMAL_ID = B.ANIMAL_ID WHERE A.DATETIME IS NULL ORDER BY B.ANIMAL_ID 있었는데요 없었습니다 SELECT A.ANIMAL_ID, B.NAME F..
[Programmers/Level 2] JOIN(MySQL)
·
Programmers/Level 1~2
Level 2 조건에 맞는 도서와 저자 리스트 출력하기 BOOK 테이블과 AUTHOR 테이블을 저자의 아이디를 기준으로 묶는다. SELECT A.BOOK_ID, B.AUTHOR_NAME, DATE_FORMAT(A.PUBLISHED_DATE, '%Y-%m-%d') AS 'PUBLISHED_DATE' FROM BOOK A INNER JOIN AUTHOR B ON A.AUTHOR_ID = B.AUTHOR_ID WHERE A.CATEGORY = '경제' ORDER BY A.PUBLISHED_DATE ASC 상품 별 오프라인 매출 구하기 PRODUCT 테이블과 OFFLINE_SALE 테이블을 상품 아이디를 기준으로 묶는다. 그리고 상품 코드로 상품들을 구분하고 상품 코드별 판매량의 총합과 상품의 가격을 곱한 값을..
[Programmers/Level 2] GROUP BY(MySQL)
·
Programmers/Level 1~2
Level 2 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 GROUP BY로 자동차를 종류별로 구분한다. 옵션이 쉼표로 구분되어 있는 문자열이기 때문에 '%옵션 정보%'를 통하여 통풍시트, 열선시트, 가죽시트를 옵션으로 포함하는 자동차만 따진다. SELECT A.CAR_TYPE, COUNT(A.CAR_TYPE) AS CARS FROM CAR_RENTAL_COMPANY_CAR A WHERE (A.OPTIONS LIKE '%통풍시트%') OR (A.OPTIONS LIKE '%열선시트%') OR (A.OPTIONS LIKE '%가죽시트%') GROUP BY A.CAR_TYPE ORDER BY A.CAR_TYPE ASC 진료과별 총 예약 횟수 출력하기 진료과 코드별로 예약 건수를 구분한다. 예약 날짜에..
[Programmers/Level 1~2] SUM, MAX, MIN(MySQL)
·
Programmers/Level 1~2
Level 1 가장 비싼 상품 구하기 SELECT MAX(A.PRICE) AS MAX_PRICE FROM PRODUCT A 최댓값 구하기 SELECT MAX(A.DATETIME) AS DATETIME FROM ANIMAL_INS A Level 2 가격이 제일 비싼 상품의 정보 출력하기 SELECT A.PRODUCT_ID, A.PRODUCT_NAME, A.PRODUCT_CD, A.CATEGORY, A.PRICE FROM FOOD_PRODUCT A ORDER BY A.PRICE DESC LIMIT 1 최솟값 구하기 SELECT MIN(A.DATETIME) AS DATETIME FROM ANIMAL_INS A 동물 수 구하기 SELECT COUNT(*) FROM ANIMAL_INS 중복 제거하기 이름의 중복을..
[Programmers/Level 1~2] SELECT(MySQL)
·
Programmers/Level 1~2
Level 1 과일로 만든 아이스크림 고르기 아이스크림의 총 주문량은 FIRST_HALF 테이블에 있고, 아이스크림의 주 성분은 ICECREAM_INFO 테이블에 있으므로 INNER JOIN을 통해 각 테이블의 FLAVOR 정보가 같은 것들만 묶어준다. 총 주문량이 3000을 넘어가고 주 성분이 과일인 아이스크림을 찾아야 하므로 WHERE을 통해 조건식을 세워준다. 마지막으로 총 주문량을 내림차순으로 정렬하고 조건을 만족하는 모든 아이스크림의 맛을 출력해준다. SELECT A.FLAVOR FROM FIRST_HALF A INNER JOIN ICECREAM_INFO B ON (A.FLAVOR = B.FLAVOR) WHERE (A.TOTAL_ORDER > 3000) AND (B.INGREDIENT_TYPE ..