프로그래머스 SQL 고득점 kit 10일차( GROUP BY 8문제) 1. 문자열과 숫자열"km"등의 단위를 표기하기 위해 concat을 쓸 경우, 문자열이 되기 때문에 해당 컬럼을 기준으로 정렬할 경우 문자열 순서로 정렬이 되므로 주의한다.SELECT ROUTE, CONCAT(ROUND(SUM(D_BETWEEN_DIST),1),"km") AS TOTAL_DISTANCE, CONCAT(ROUND(AVG(D_BETWEEN_DIST),2),"km") AS AVERAGE_DISTANCEFROM SUBWAY_DISTANCEGROUP BY ROUTEORDER BY ROUND(SUM(D_BETWEEN_DIST),1) DESC
프로그래머스 SQL 고득점 kit 9일차(GROUP BY 12문제 / 24문제) 1. 재귀함수 RECURSIVEWITH RECURSIVE 테이블이름_작명 AS ( SELECT 시작할 값 AS 별칭 UNION ALL SELECT 별칭+1(원하는 계산식) FROM 위에서_작명한_테이블이름 WHERE 필요시 원하는 조건)SELECT *FROM 위에서_작명한_테이블이름 2. 나눗셈 (몫과 나머지)SELECT 5/2 # 2.5SELECT 5 DIV 2 # 몫 2SELECT 5%2 # 나머지 1SELECT 5 MOD 2 # 나머지 1 3. IFNULL과 COALESCE1) IFNULL: NULL인지 아닌지 1개의 값 비교, MYSQL 전용SELECT IFNULL(NULL, 'defaul..
프로그래머스 SQL 고득점 kit 8일차( IS NULL 8문제) 1. 숫자 계산1) 반올림 :RoundSELECT ROUND(123.456, 2) # 123.462) 올림 : CEILSELECT CEIL(123.456, 2) # 1243) 내림: FLOORSELECT FLOOR(123.456)# 123 2. 천단위 구분(통화): FORMATSELECT FORMAT(1000000000,0)# 1,000,000,000
프로그래머스 SQL 고득점 kit 7일차( SUM, MAXm MIN 10문제) 1. RANK1) RANK()- 데이터에 순위를 매기는 함수- 동일 값에 동일 순위, 이후에는 순위를 건너뛴다SELECT column1, column2, RANK() OVER (PARTITION BY column1 ORDER BY column2 DESC) AS rankFROM table_name;2) DENSE_RANK()- 동일 값에 동일 순위, 순위 연속SELECT column1, column2, DENSE_RANK() OVER (PARTITION BY column1 ORDER BY column2 DESC) AS rankFROM table_name;3) ROW_NUMBER()- 모두 고유 순위를 부여한..
프로그래머스 SQL 고득점 kit 6일차( SELECT level4-1문제, level5-1문제, SELECT 문제 풀이 끝!) 1.UNION1) UNION ALL- 중복된 행을 포함하여 반환 (모든 행 포함), 중복제거 및 정렬을 하지 않아 UNION보다 성능이 좋다SELECT id, name FROM table1UNION ALLSELECT id, name FROM table2;2) UNION - 중복된 행을 제거한 결과를 반환한다SELECT id, name FROM table1UNIONSELECT id, name FROM table2;3) 문제풀이SELECT *FROM ( SELECT DATE_FORMAT(SALES_DATE,'%Y-%m-%d') AS SALES_DATE, PRODUCT_ID, ..
프로그래머스 SQL 고득점 kit 5일차( SELECT level3-3문제, level 3 끝!, level4-2문제) 1. 조건문 CASE- 순차적으로 위에서부터 계산하여 조건을 만족하지 않은 행만 다음 조건으로 넘어간다.(중복적용 x)CASE WHEN 조건1 THEN 결과1 WHEN 조건2 THEN 결과2 ... ELSE 기본결과END AS 별칭(필요시) 2. 윈도우 함수- 특정 그룹(WINDOW) 내에서 각 행에 대해 연산을 수행하는 함수- OVER : 윈도우 함수를 쓸 때 반드시 필요하며, 특정 그룹을 정의하거나 데이터를 정렬할 때 사용- 행과 관련된 데이터를 계산하면서도 원본 행을 유지 1) PERCENTE RANK- 데이터의 백분율 순위 → 0~1사이의 값을 반환PERCE..
프로그래머스 SQL 고득점 kit 4일차( SELECT level2-3문제, lever2 끝!) 1. WITH- 복잡한 쿼리를 읽기 쉽게 하기 위해 서브쿼리를 미리 선언한 다음 재사용 할 수 있다.(변수 처럼)- WITH 별칭 AS 서브쿼리WITH WANT_NUM AS ( SELECT CODE FROM SKILLCODES WHERE NAME IN ('Python', 'C#')) 2. IN과 EXISTSINEXISTS값을 정확하게 매칭할때 (리스트에 포함 여부)조건이 참이되는 행의 존재 여부 (동적으로 검사할때)전체를 한번에 비교한 행씩 비교 (성능 최적화)SELECT ID, EMAIL, FIRST_NAME, LAST_NAMEFROM DEVELOPERSWHERE EXISTS ( SEL..
프로그래머스 SQL 고득점 kit 3일차( SELECT level2-2문제)1. 서브쿼리와 JOIN구분서브쿼리JOIN언제 사용?- 비교적 간단한 조건처리- 단일 값 반환(스칼라 서브쿼리)- 테이블간 관계가 명확하지 않거나 불필요할 때- 복잡한 관계를 처리- 테이블 간 연관된 데이터를 결합성능- 소규모 데이터에서 더 효율적일 수 있음- 서브쿼리가 반복 실행되면 성능 저하- 데이터 크기가 크거나 인덱스를 활용할 경우 효율적- 실행 계획 최적화로 반복 작업 줄임 2. 서브쿼리를 JOIN으로 리팩토링1) 서브쿼리SELECT ITEM_ID, ITEM_NAME, RARITYFROM ITEM_INFOWHERE ITEM_ID IN (SELECT ITEM_ID FROM ITEM_TREE..
- Total
- Today
- Yesterday
- 루틴
- 경제
- 빅데이터 분석기사
- llm
- opic
- 운동
- 줄넘기
- 기초
- IH
- 30분
- 아침
- 습관
- C언어
- 뉴스
- 영어회화
- 실기
- 아침운동
- Ai
- ChatGPT
- 스크랩
- 미라클모닝
- 고득점 Kit
- SQL
- 다이어트
- 갓생
- 오픽
- 프로그래머스
- 티스토리챌린지
- Python
- 오블완
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
31 |