20강 | 결합이 느리다면 정리 1. 상황에 따른 최적의 결합 알고리즘 알고리즘의 장단점 결합 대상 레코드 수의 관점에서 최적의 결합 알고리즘 정리 소규모 - 소규모 결합 대상 테이블이 작은 경우에는 어떤 알고리즘을 사용해도 성능 차이가 크지 않다. 소규모 - 대규모 소규모 테이블을 구동하는 Nested Loops를 사용합니다. 대규모 테이블의 결합키에 인덱스 있는 것이 중요, 내부 테이블의 결합 대상 레코드가 너무 많다면 구동 테이블과 내부 테이블을 변경 도는 hash를 사용해볼 것을 검토 대규모 - 대규모 hash를 사용, 결합 키로 정렬되어 있는 상태라면 Sort Merge를 사용 2. 실행 계획 제어 DBMS마다 실행 계획을 제어할 수 있다. 다만 MySQL은 결합 알고리즘 자체가 Nested L..
19강 | 결합 알고리즘과 성능 정리 옵티마이저가 선택 가능한 결합 알고리즘 (데이터의 크기 또는 결합 키의 분산으로 결정) Nested Loops Hash Sort Merge Nested Loops 알고리즘 각종 결합 알고리즘의 기본이 되는 알고리즘 중첩 반복을 사용하는 알고리즘 세부 처리 외부 테이블(TableA)에서 레코드를 하나씩 반복하며 스캔 외부 테이블 레코드 하나마다 내부테이블(TableB)의 레코드를 하나씩 스캔에서 결합조건에 맞으면 리턴 위의 과정을 외부 테이블 모든 레코드에 반복 특징 각 테이블의 결합 대상 레코드 수가 R(A) ,R(B) 일때 접근되는 레코드 수는 R(A) X R(B)가 된다. 실행시간은 레코드 수에 비례 한번의 단계에서 처리하는 레코드 수가 적으므로 Hash 또는 S..
이상한 나라의 객체 객체 정의 객체란 식별 가능한 개체 또는 사물이다. 객체는 구별 가능한 식별자,특징적인 행동,변경 가능한 상태를 가진다. 상태 특정시점에 객체가 가지고 있는 정보의 집합으로 객체의 구조적 특징을 표현한다. 객체의 상태는 객체에 존재하는 정적인 프로퍼티와 동적인 프로퍼티 값으로 구성된다. 객체는 스스로의 행동의 의해서만 상태가 변경되는 것을 보장함으로써 객체의 자율성을 유지한다. 행동 행동이란 외부의 요청 또는 수신된 메시지에 응답하기 위해 동작하고 반응하는 활동이다. 부수효과를 초래한다. → 객체가 취하는 행동은 객체 자신의 상태를 변경시킨다. 상태와 행동사이의 관계 객체의 행동은 상태에 영향을 받는다. 객체의 행동은 상태를 변경시킨다. 행동이 상태를 결정한다 협력 객체의 행동은 객체..
역할,책임,협력 역할,책임,협력이 객체지향 애플리케이션의 윤곽을 결정한다. 역할의 특징 여러 객체가 동일한 역할을 수행할 수 있다. 역할은 대체 가능성을 의미한다. 각 객체는 책임을 수행하는 방법을 자율적으로 선택할 수 있다. 하나의 객체가 동시에 여러 역할을 수행할 수 있다. 협력 객체는 다른 객체와의 협력을 통해 기능을 구현하게 된다. 협력속의 객체 특징 다른 객체에 협력적이어야 하며, 자율적이어야 한다. 객체는 데이터와 프로세스를 함께 지닌다. 객체지향에서 협력은 메시지를 전송하는 객체, 송신자와 메세지를 수신하는 객체, 수신자 사이의 관계로 구성된다. 메서드와 자율성 메서드(method) : 객체가 수신된 메세지를 처리하는 방법 외부의 요청이 무엇인지 표현하는 메시지와 요청을 처리하기 위한 구체적..
18강 | 기능적 관점으로 구분하는 결합의 종류 17강은 5장의 내용을 정리한 부분이라, 스킵했습니다. 정리 Employees 테이블 Department 테이블 테이블 생성 -- Employees 테이블 생성 CREATE TABLE Employees ( emp_id INT PRIMARY KEY, emp_name VARCHAR(50), dept_id INT, FOREIGN KEY (dept_id) REFERENCES Department(dept_id) ); -- Department 테이블 생성 CREATE TABLE Department ( dept_id INT PRIMARY KEY, dept_name VARCHAR(50) ); -- Employees 테이블에 데이터 추가 INSERT INTO Employe..
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 ..