Transaction

Transaction ? Atomic하게 실행되어야 하는 SQL 들을 묶어서 하나의 작업처럼 처리하는 방법, 즉 여러개의 쿼리가 동시에 실행되었을 때 데이터의 정합성이 문제가 되지 않는 경우를 Atomic 하다라고 한다.DDL / DML 중 레코드를 수정/추가/삭제한 것에만 의미가 있음.SELECT 에는 transaction을 사용할 이유가 없음BEGIN 과 END 혹은, BEGIN 과 COMMIT 사이에  해당 SQL 들을 사용하는 것을 Transaction 을 이용하는 방법.ROLLBACKTransactio의 4대 특성 ( ACID )Atomicity(원자성) : Transaction 내의 모든 연산들은 모두 실행되거나, 모두 실행되지 않아야 한다는 특성을 말한다. 즉 transaction은 하나의 ..

JOIN

JOIN 이란 ? SQL 조인은 두 개 혹은 그 이상의 테이블들을 공통 필드를 가지고 merge 하는데 사용된다.이는 star schema로 구성된 테이블들로 분산되어 있던 정보를 통합하는데 사용된다.  왼쪽 테이블을 LEFT 라고 하고, 오른쪽 테이블을 RIGHT 라하면 JOIN의 결과는 방식에 상관없이 양쪽의 필드를 모두 가진 새로운 테이블을 만들어내게 된다.  JOIN 의 방식에 따라 생성되는 테이블이 달라진다. 여러 JOIN 의 종류는 아래와 같이 나눌 수 있다.  JOIN 의 문법./*____ 자리에 위에서 보이는 INNER,LEFT,RIGHT,FULL,OUTER .. 등이 올 수 있다.*/SELECT FROM ____ JOIN ON  JOIN 시 다음사항을 반드시 고려해야 한다.중복된 레코..

GROUP BY 와 AGGREGATE 그리고 CTAS

GROUP BY & Aggregate Fucntion.GROUP BY란, 테이블의 레코드를 그룹화하여 그룹별로 다양한 정보를 계산할 때 사용하는 연산자이다. GROUP BY는 다음 두단계로 이뤄진다.먼저 그룹화를 진행할 필드를 결정한다 이때 필드는 하나 이상의 필드가 될 수 있다.이 후 그룹별로 계산할 내용을 결정한다 이때 aggregate 함수를 사용해 그룹별 계산을 진행한다보통 COUNT,SUM,AVG,MIN,MAX .. 등의 함수를 통해 그룹별 계산을 진행한다. 다음과 같은 데이터 베이스가 있다고 할 때 몇가지 예시를 들어 GROUP BY 사용법을 사용해보자. 1. 월별 총 섹션수 구하기./* 만약 raw_data 스키마의 session_timestamp 테이블의 정보를 불러와..