목록SQL (30)
오랑우탄의 반란

윈도우 함수 총정리 1 에서는 윈도우 함수의 기본적 사용부터 집계, 순위 매기기 등의 활용까지 살펴볼 예정입니다. 윈도우 함수 WINDOW FUNCTION윈도우 함수는 서브쿼리처럼 쓰이지만 서브쿼리보다 간단하고 가동성이 높은 특징을 가졌습니다.특히 이동평균, 누적합계, 순위 계산에 유용하게 쓰입니다. 기본 문법SELECT 집계함수() OVER (PARTITION BY {컬럼명1}, ORDER BY {컬럼명2}) FROM {테이블}; PARTITION BY는 GROUP BY 와 동일한 기능으로 특정 기준으로 윈도우함수 내에서 분류ORDER BY는 윈도우함수 내에서 정렬될 기준 아래 기본적인 사용 예시를 보겠습니다. 전체 직원을 대상으로 월급을 많이 받는 순위 매기기SELECT employee_id, d..

오늘은 디비버에서 테이블을 생성하고, 내용을 변경하고, 마지막으로 테이블끼리 키로 연결해주는 법을 살펴보겠습니다. 테이블 생성 및 삭제 테이블 생성, 데이터 삽입, 그리고 삭제는 단일 실행만 가능합니다. CREATECREATE TABLE {테이블명} ({컬럼명1} {자료형} PRIMARY KEY # 일반적으로 PK가 첫 번째옴{컬럼명2} {자료형} {제약조건} # 서로 관계를 가지고 있는 RDB 특성상 제약조건이 필요할때가 있음); 테이블을 생성할 때는 데이터 무결성을 보장하기 위해 아래와 같은 제약 조건을 추가해야 합니다. UNIQUE해당 열에 중복된 값 입력 불가NOT NULLNULL 값 허용 안됨PRIMARY KEY기본키로 설정 (UNIQUE + NOT NULL)FOREIGN KEY다른 ..

오늘은 MYSQL 데이터베이스 구조, 데이터 모델링, 그리고 ERD 관련해서 간단하게 살펴보겠습니다. MySQL DB 구조데이터베이스를 직접 액세스하기 위해 SQL 을 사용하는데요, 이때 흔히 사용하는 데이터 조작 언어 (select) 외에도 여러 종류의 구문이 존재합니다. 데이터 조작DML (Data Manipulation Language)데이터 조회, 삽입, 변경, 삭제SELECT, INSERT, UPDATE, DELETE데이터 정의DDL (Data Definition Language)테이블 생성, 삭제, 수정CREATE, DROP, ALTER데이터 관리DCL (Data Control Language)데이터 접근권한 관리GRANT, REVOKE정보 조회테이블 조회, 테이블 속성 조회SHOW, DES..

오늘도 오랑이는 문제를 풉니다. 1321. Restaurant Growth 풀이 과정주어진 날짜 중 7일에 대한 합과 평균을 구해야 하는 문제입니다. 윈도우 함수를 사용해 범위를 지정해서 특정 날짜 구간에 대해 집계를 할 수 있는데요, range로 날짜 범위를 구할 수 있습니다. 이때 interval 은 datatype 이 date 인 경우에만 사용 가능하다는 점을 주의해야 합니다. sum(amount) over (order by visited_on range between interval '6' day preceding and current row) as amount 해당 조건을 from 서브쿼리로 넣어주면 7일에 대한 합과 평균을 구할 수 있습니다. 이때 행이 중복으로 들어가지 않게 group by ..

오늘도 오랑이는 문제를 풉니다. 1341. Movie Rating 풀이 과정두 조건에 대해 결과물을 출력해서 union 으로 연결해주는 문제입니다.첫번째 조건에 대해 MovieRating 과 Users 테이블을 조인해서 user_id 기준으로 그룹해 rating 의 개수에 대한 max를 구하는 것을 생각했었는데 쿼리를 실행해보니 오류가 뜨더군요. 다른 풀이를 참고했더니 더 간단한 방법으로 name 기준으로 group해서 rating 개수와 name 기준 정렬해서 맨 위의 결과 하나만 추출하면 조건에서 '동순위일 경우 알파벳순으로 먼저 오는 이름 출력'에 대한 조건을 자동으로 충족하게 됩니다. select name as results from movierating join users using(user_..

오늘도 오랑이는 문제를 풉니다. 626. Exchange Seats 풀이 과정이번 문제에서는 다양한 풀이를 살펴볼 예정입니다. 1 max()우선 첫번째 풀이입니다. 이 풀이는 id 번호를 변경해서 student 를 거기에 맞춰주는 형식입니다. id가 홀수인 경우, 1을 더해주고, id가 홀수인 경우 1을 빼줍니다. 마지막 id가 홀수인 경우 그대로 둬야 하기 때문에 그거에 대한 조건도 적어줍니다. select case when id = (select max(id) from seat) and id % 2 = 1 then id when id % 2 = 1 then id + 1 else id - 1 end as id, studentfrom seat ord..

오늘도 오랑이는 문제를 풉니다. 1907. Count Salary Categories 풀이 과정첫 시도는 아래와 같이 각 가격에 대한 case를 나눠서 풀었습니다. 하지만 이렇게 풀 경우, 보이는 바와 같이 'Average Salary' 에 대한 칼럼이 나오지 않습니다. select case when income 50000 then 'High Salary' else 'Average Salary' end as category, count(account_id) as accounts_countfrom accounts group by category ifnull 로 count를 감싸는 것으로 해결되는 문제인가 싶었지만 생각을 해보니 오랑이가 작성한 case 문은 True/F..

오늘도 오랑이는 문제를 풉니다. 1204. Last Person to Fit in the Bus 풀이 과정turn 기준으로 정렬한 것에 대한 각 weight 의 누적합이 필요한 문제입니다.누적합을 구할 수 있는 방법은 self join 으로 sum, group by 하는 방법과, sum() over() window function 을 사용하는 방법 크게 두 가지가 있습니다. 누적합 윈도우 함수SELECT column1, column2, SUM(더할 칼럼) OVER (ORDER BY 정렬기준) as CumulativeSumFROM table_name; 사용예시SELECT Date, Sales, SUM(Sales) OVER (ORDER BY Date) as CumulativeSalesFROM daily_s..