SQL 문제풀이

SQL 문제풀이

[프로그래머스 SQL] LV.3 카테고리 별 도서 판매량 집계하기

❓ Question ❗ Answer SELECT book.category, SUM(sales.sales) FROM book LEFT OUTER JOIN book_sales sales ON book.book_id = sales.book_id WHERE DATE_FORMAT(sales.sales_date, '%Y%m') = '202201' GROUP BY book.category ORDER BY book.category 📌 Discussion - WHERE -> GROUP BY -> SELECT 순서 - JOIN으로 병합하고 WHERE로 조건에 맞는 레코드 추출

SQL 문제풀이

[프로그래머스 SQL] LV.4 보호소에서 중성화한 동물

❓ Question ❗ Answer SELECT ins.animal_id, ins.animal_type, ins.name FROM animal_ins ins LEFT OUTER JOIN animal_outs outs ON ins.animal_id = outs.animal_id WHERE (ins.sex_upon_intake LIKE '%Intact%') AND (outs.sex_upon_outcome LIKE '%Spayed%' OR outs.sex_upon_outcome LIKE '%Neutered%') ORDER BY ins.animal_id; 📌 Discussion join으로 동일한 key를 가진 데이터를 추출 후 WHERE 문에서 LIKE 조건으로 원하는 데이터를 필터링

SQL 문제풀이

[프로그래머스 SQL] LV.3 오랜 기간 보호한 동물(2)

❓ Question ❗ Answer SELECT ins.animal_id, ins.name FROM animal_ins ins LEFT OUTER JOIN animal_outs outs ON ins.animal_id = outs.animal_id ORDER BY outs.datetime - ins.datetime DESC LIMIT 2; 📌 Discussion - ORDER BY에서도 집계량 활용이 가능하다.

SQL 문제풀이

[프로그래머스 SQL] LV.2 상품 별 오프라인 매출 구하기

❓ Question ❗ Answer SELECT product.product_code 상품코드, SUM(product.price*sale.sales_amount) 매출액 FROM product product LEFT OUTER JOIN offline_sale sale ON product.product_id = sale.product_id WHERE sale.sales_amount IS NOT NULL GROUP BY product.product_code ORDER BY 매출액 DESC, 상품코드; 📌 Discussion GROUP BY 이후에 집계함수 활용 WHERE -> GROUP BY -> HAVING 순으로 작동

SQL 문제풀이

[프로그래머스 SQL] LV.2 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기

❓ Question ❗ Answer SELECT car_type, COUNT(*) 'CARS' FROM car_rental_company_car WHERE options LIKE '%시트%' GROUP BY car_type ORDER BY car_type; 📌 Discussion - 시트의 종류 세개 중에 하나만 포함되면 되므로 LIKE '%시트%'로 조건 지정

SQL 문제풀이

[프로그래머스 SQL] LV.3 있었는데요 없었습니다

❓ Question ❗ Answer SELECT ins.animal_id, ins.name FROM animal_ins ins LEFT OUTER JOIN animal_outs outs ON ins.animal_id = outs.animal_id WHERE ins.datetime > outs.datetime ORDER BY ins.datetime; 📌 Discussion LEFT OUTER JOIN으로 JOIN 후에도 오른쪽 테이블의 값이 NULL인 레코드도 가져온다. WHERE로 JOIN 후 합쳐진 테이블에서 컬럼 데이터를 비교

SQL 문제풀이

[프로그래머스 SQL] LV.3 오랜 기간 보호한 동물(1)

❓ Question ❗ Answer SELECT ins.name, ins.datetime FROM animal_ins ins LEFT OUTER JOIN animal_outs outs ON ins.animal_id = outs.animal_id WHERE outs.datetime IS NULL ORDER BY ins.datetime LIMIT 3; 📌 Discussion LEFT OUTER JOIN으로 두 테이블을 결합하여 오른쪽 테이블이 NULL값인 레코드도 모두 불러옴 이 경우에 누락된 레코드가 적기에 WHERE절에서 추가 옵션을 줘서 레코드를 더 잘 활용할 수 있다. WHERE절에서 outs.datetim이 없는 레코드를 누락시킴 LIMIT 3로 상위 세가지 레코드만 추출

SQL 문제풀이

[프로그래머스 SQL] LV.2 진료과별 총 예약 횟수 출력하기

❓ Question ❗ Answer SELECT mcdp_cd '진료과코드', COUNT(*) '5월예약건수' FROM appointment WHERE DATE_FORMAT(apnt_ymd,'%Y%m') = '202205' GROUP BY mcdp_cd ORDER BY 5월예약건수, 진료과코드; 📌 Discussion DATE_FORMAT(apnt_ymd,'%Y%m') = '202205'로 조건 설정 LEFT로 '2022-05'로 시작하는 데이터라는 조건 설정해도 가능 GROUP BY로 무리짓고 COUNT로 집계 ORDER BY는 이미 불러온 레코드에 있는 열에 대해 정렬하므로 문자열로 열을 부르면 정렬 불가

냄비짱
'SQL 문제풀이' 카테고리의 글 목록 (11 Page)