일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- if문
- sql문풀
- SQL테스트
- UNION
- 셀프조인
- with절
- 코테
- levle1
- 그로스해킹
- 파이썬문풀
- mysql
- 데이터분석
- 코딩테스트
- join
- 문풀
- 약수구하기
- 프로그래머스
- SQL고득점KIT
- 프로그래머스문풀
- 위키독스
- 서브쿼리
- case문
- SQL
- leetcode문풀
- 윈도우함수
- 파이썬
- leetcode
- 활성사용자수
- 데이터리안
- GROUPBY
- Today
- Total
목록SQL (14)
꿈은 데이터분석가, 취미는 계획
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 연간 평가점수에 해당하는 평가 등급 및 성과금 조회하기 링크: https://school.programmers.co.kr/learn/courses/30/lessons/284528 문제(일부): 평가등급과 성과금, 평가자 정보 조회 평가등급은 상,하반기 평균점수, 성과금 비율은 평가등급에 따라 부여됨 1. WITH절 사용 1) 상, 하반기 평균점수를 구하는 WITH절 생성 2) CASE WHEN 구문으로 1)의 평균 점수에 따라 평가등급과 성과금 비율 부여 3) 2)의 with절과 평가자 테이블을 JOIN하여 정보조회 WITH AVG_SCORE AS( SELECT EMP_NO, AVG(SCORE) AS AVG_SCORE FROM HR..
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 언어별 개발자 분류하기 링크: https://school.programmers.co.kr/learn/courses/30/lessons/276036 문제(일부): 2개의 테이블 정보를 활용하여 보유한 스킬별로 등급부여 0.BIT_OR 집계함수 이해하기 여러 사용자의 권한을 그룹별로 합쳐서 최대 권한을 계산할 수 있음 부서 ID가 10인 경우, 권한 1, 2, 4가 있는데, 이를 OR 연산하면 1 | 2 | 4 = 7이 됩니다. 즉, 읽기, 쓰기, 실행 권한 모두 있습니다. 부서 ID가 20인 경우, 권한 3과 6을 OR 연산하면 3 | 6 = 7이 되므로 같은 권한을 가지게 됩니다. CREATE TABLE UserPermissions..
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 입양 시각 구하기(2) 링크: https://school.programmers.co.kr/learn/courses/30/lessons/59413 문제(일부): 0시부터 23시까지, 각 시간대별로 입양이 몇 건이나 발생했는지 조회 0. 재귀쿼리 활용하기 0~23시까지 입양이 발생하지 않은 경우 0으로 count해야 함 1) 재귀쿼리를 활용해서 0~23을 만들기 2) right join으로 발생횟수 count *재귀쿼리 with절에 첫번째 select문은 1회만 실행,초기값with절의 두번째 select문은 where조건을 만족할 때까지 반복 => 0~23까지의 열 생성 with recursive time as ( select 0 as..
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 링크: https://school.programmers.co.kr/learn/courses/30/lessons/151139#qna 문제(일부): 특정기간동안 총 대여횟수가 5회 이상인 자동차들에 대해서(그룹 필터링1), 월별 자동차 ID별 총 대여횟수(그룹 필터링2) 1. 서브쿼리 활용하기 서브쿼리에 그룹 필터링1의 조건을 넣고 메인쿼리에 그룹필터링 2의 조건을 넣음, where절에 그룹필터링 1과 일치하는 CAR_ID사용 SELECT MONTH(START_DATE) MONTH, CAR_ID, COUNT(*) RECORDS FROM CAR_RENTAL_COMPANY_RENTAL_H..
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 대장균의 크기에 따라 분류하기 링크: https://school.programmers.co.kr/learn/courses/30/lessons/301649 문제(일부): 개체의 크기를 내림차순으로 정렬했을 때 0% ~ 25% 를 'CRITICAL', 26% ~ 50% 를 'HIGH', 51% ~ 75% 를 'MEDIUM', 76% ~ 100% 를 'LOW' 라고 분류 1. 윈도우 함수 PERCENT_RANK활용하기 1) WITH절에서 PERCENT_RANK를 사용하여 행별 백분율을 표현 2) CASE구문으로 등급을 부여 WITH A AS ( SELECT ID,PERCENT_RANK() OVER(ORDER BY SIZE_OF_COLON..
출처: [프로그래머스 스쿨 - 코딩테스트 연습 - MY SQL 문제] : 연도별 대장균 크기의 편차 구하기 링크: https://school.programmers.co.kr/learn/courses/30/lessons/299310 문제(일부): ~ 연도별 대장균 크기의 편차는 분화된 연도별 가장 큰 대장균의 크기 - 각 대장균의 크기로 구함 WITH절과 JOIN을 사용한 풀이 1) WITH절에서 연도별 MAX크기 구하기, 2) 연도를 기준을 JOIN하여 편차 구하기(연도별 최대값 - 각 레코드의 크기) WITH MAX_S AS ( SELECT MAX(SIZE_OF_COLONY) AS MAX_SIZE , YEAR(DIFFERENTIATION_DATE) AS YEAR FROM ECOLI_DATA GROUP ..