16강 | SQL에서는 반복을 어떻게 표현할까? 정리 CASE 식과 윈도우 함수를 이용한다. 최대 반복 횟수가 정해진 경우 유용하게 사용할 수 있다. 반복 횟수가 정해지지 않은 경우 인접 리스트 모델과 재귀 쿼리를 사용한다. 중첩집합 모델을 이용하여 계층 구조를 표현한다. 예제문제 1 매출 계산을 하는 테이블이있을 때, 각 기업의 연도별 매출 변화를 나타내야한다. var 필드를 추가하여 매출이 이전보다 올랐을 경우 +, 내렸을 경우 - , 동일한 경우 = 를 넣는다. 해당 문제는 15강에서 예시로 보였던 반복계 코드에 해당하는 문제이며, CASE식과 윈도우 함수를 이용하여 포장계 코드로 변경해야 한다. Sales 테이블 최종적으로 구해야할 Sales2 테이블 테이블 생성 -- Sales 테이블 생성 CR..
15강 | 반복계의 공포 정리 SQL은 반복문이 없다. SQL은 처음부터 반복문을 지양하며 만든 언어이며, 그 이유는 최종 사용자의 생산성 때문이다. 반복계 코드 테이블 단위를 레코드 단위로 쪼개어, 나눠진 레코드를 하나씩 반복문에 적용하는 방법 CREATE OR REPLACE PROCEDURE PROC_INSERT_VAR IS /* 커서 선언 */ CURSOR c_sales IS SELECT company, year, sale FROM Sales ORDER BY company, year; /* 레코드 타입 선언 */ rec_sales c_sales %ROWTYPE; /* 카운터 */ i_pre_sale INTEGER :=0; c_company CHAR(1) :='*'; c_var CHAR(1) :='*..
13강 | 자르기 정리 Group By 구의 기능 자르기 집약 키(기준)에 따른 자르기 단순한 필드뿐만 아니라, CAS와 같이 복잡한 수식을 기준으로도 자를 수 있다. GROUP BY 구와 SELECT 구에 모두 적을 수 있다. PARTITION BY 구를 사용한 자르기 GROUP BY의 집약 기능을 제외하면 실질적인 기능에 차이가 없음(차이점 : PARTITION BY는 기존 행의 세세한 정보가 그대로 남은 채로 나뉨 → 집약이 안되기 때문 !!) CASE,계산식 등 복잡한 기준을 사용할 수 있음 예제문제 1 Persons 테이블에서 첫문자 알파벳마다 몇명의 사람이 존재하는지 계산하여야 한다. Persons 테이블 생성 CREATE TABLE Persons ( name VARCHAR(255), age ..
12강 | 집약 정리 집약 함수 COUNT SUM AVG MAX MIN 여러 개의 레코드를 한 개의 레코드로 집약 CASE 식과 GROUP BY를 응용한다 CASE를 이용해 해당 레코드에 필요한 필드면 데이터를 반환 아니면 NULL을 반환 집약,해시,정렬 집약시 경우에 따라 정렬 또는 해시를 사용한다. 최근 Group By를 사용하는 집약에서 정렬보다 해시를 사용하는 경우가 많다 해시 이용 : GROUP BY에서 지정한 필드를 해시함수로 해시 키로 변환한 후, 동일한 해시 키를 가진 그룹끼리 집약한다. 정렬과 해시는 메모리를 만히 사용하므로, 충분한 해시용(정렬용) 워킹 메모리가 확보되지 않으면 스왑 발생 예제문제 1 data_type 별로 필요한 데이터 값을 구해야 한다. 이때 data_type이 A일..
10강 | UNION이 필요한 경우 정리 UNION 사용할 수 밖에 없는 경우 ▶️ 여러개 테이블 검색 결과를 머지할 때 UNION 사용 좋은 점 좋은 인덱스를 사용한다. union을 사용하지 않을 시 풀스캔 발생 가능성 이전 블로그에 작성한 내용처럼 case도 이용이 가능하지만 필요없는 결합으로 성능이 낮아질 가능성이 있다. 결론 상황에 맞게 적절히 사용 예제문제 아래 테이블에서 date가 2013-11-01이고,flag가 True인 레코드를 검색 threeElements 테이블 기대값 풀이법 테이블 생성 1) UNION을 사용 코드 select `key`,name,date_1,flg_1,date_2,flg_2,date_3,flg_3 from example.threeElements where date_..
이번 장에서는 집계와 조건분기를 효율적으로 진행하는 방법을 알아보려고 한다. 1. 집계 대상으로 조건 분기 예제 문제 Population 테이블이 존재하며, 그 지역의 이름과 각 성별마다의 인구 정보를 담고 있다. 원하는 결과 지역의 성별에 따른 인구수를 한 row에 확인할 수 있도록 할 것. 1️⃣ union을 사용한 방법 각 성별마다의 인구수를 구해, union으로 합쳐 하나의 테이블로 정리하는 방법이다. 아래의 쿼리를 통해 3가지 속성을 가진 하나의 테이블로 정리가 가능하다. select prefecture, pop as pop_men , null as pop_wom from example.population where sex = 1 union select prefecture, null as pop..
[SQL 레벨업] 7강. 조건 분기,집합 연산, 윈도우 함수,갱신 저번 글 7강에서 집합 연산을 공부하면서 UNION에 대해 정리하는 시간을 가졌었다. 그런데 이번 8강에서는 UNION을 단순히 생각나는대로 사용하지 않고, 어떻게 하면 효율적으로 UNION을 사용하는지 정리해볼 예정이다. 1. UNION 사용시 주의할 점 union을 사용할 때 주의해야할 점은 내부적으로 여러개의 select 구문을 실행한다는 것이다. 우리는 union으로 합친 쿼리들을 한번의 실행으로 받아드릴 수 있겠지만, 실제로 내부에서는 합친 select 구문만큼 실행되고 있기 때문에, 테이블에 접근하는 횟수가 많아져 I/O 비용이 크게 늘어난다. 그렇기 때문에 사용하기 전에 신중히 고려해서 사용해야 하며, UNION대신 CASE를..
mysql에서 한글 깨짐 현상이 발생했다. 현재 문자셋이 어떻게 저장되어 있는지 확인을 해보니? show variables like 'c%'; utf8말고 latin1이 여기저기 있었다,,, 설정 파일을 열어 하단에 코드를 추가해준다. my.cnf는 Unix 계열의 MySQL엔진에서 사용하는 configure 파일로, MySQL 서버는 단 하나의 설정 파일(my.cnf)만 사용한다. vim /etc/mysql/my.cnf [client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] collation-server = utf8_unicode_ci init-connect='SET NAMES utf8' character-set-s..