Database를 Master/Slave 구성해야 하는 이유, Application에서는 어떻게 활용해야하는지에 관하여 정리해보려 한다. Database Replication의 동작원리나 Database의 구성형태에 대해서는 다루지 않는다. (사실 잘 모른다.) 왜 Database를 Master/Slave로 나누었을까? Application에서는 Master/Slave DB을 활용하기 위해 어떻게 구현을 했으며 어떤 고민들이 있었을까? Master Database만 구성하였을 때의 한계점 나의 첫번째 회사는 B2B서비스를 제공하는 회사였다. 그러다보니 시스템 사용자수는 한정되어(국내/해외 법인)있었고 트래픽이 증가할일이 거의 없었다. 그렇기 때문에 Application 구성도가 굉장히 단순했다. (극단적..
데이터베이스 노트
connections 현재사용 중인 sessions, processes 수 SELECT * FROM v$resource_limit WHERE resource_name in ('processes', 'sessions', 'transactions') 현재 접속중인 세션 정보 SELECT username, program FROM v$session;
사용법 시간 더하기 DATE_ADD(기준 날짜, INTERVAL) 시간 빼기 DATE$_SUB(기준 날짜, INTERVAL) 예제 1 초 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 SECOND); 1 분 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 MINUTE); 1 시간 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 HOUR); 1 일 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 DAY); 1 달 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 MONTH); 1 년 더하기 SELECT DATE_ADD(NOW(), INTERVAL 1 YEAR); 빼기를 DATE_ADD를 사용할 수 있음 SEL..
SQL 에서 '%'같은 특수 문자는 검색이 불가능하다. 예를 들어 WHERE 조건 = '%bb' 를 하게 되면 %bb 와 일치하는 조건을 찾고 싶은거였지만, bb가 마지막에 오는 문자를 검색하게 된다. 이처럼 특수문자가 포함된 문자열은 우리가 의도한바와 다르게 작동할때가 있는데, 이럴때 사용하는 것이 ESCAPE이다. 아래와 같이 사용한다. SELECT PRODUCT_NAME FROM PROUDCT WHERE PRODUCT_NAME LIKE '%#_%' ESCAPE '#'; ESCAPE 문자를 지정한 후에, 특수 문자앞에 ESCAPE문자를 넣어준다. 이렇게 되면 ESCAPE문자 뒤에 있는 문자를 일반 문자로 인식하게되어, _(언더바)가 들어간 상품..
실행 계획이 SQL 구문의 성능을 결정 실행계획이 만들어지면 DBMS는 그것을 바탕으로 데이터 접근을 수행한다. 하지만, 데이터 양이 많은 경우에는 반응 지연이 발생하는데 첫번 째로, 앞에서 살펴본 통계정보가 부족한 경우 두번 째로는, SQL 구문이 복잡하여 옵티마이저가 최적의 경로를 선택하지 못할 경우 발생한다. => (이미 최적의 경로(방법)가 설정되어 있는데도 느린 경우) 실행계획 확인 방법 SQL 구문의 지연이 발생했을 경우 제일 먼저 실행 계획을 살펴본다. Oracle : set autotrace traceonly 3개의 기본적인 SQL 구문의 실행 계획 살펴보기 테이블 풀 스캔(Full Scan)의 실행 계획 인덱스 스캔의 실행 계획 간단한 테이블 결합의 실행 계획(조인) (Sql develo..
데이터에 접근하는 방법은 어떻게 결정할까? RDB에서 데이터 접근 절차를 결정하는 모듈을 쿼리 평가 엔진이라고 부른다. => SQL 구문(쿼리)을 처음 읽어 들이는 모듈이기도함 쿼리 평가 모듈은 추가로 파서 또는 옵티마이저와 같은 여러 개의 서브 모듈로 구성된다. 쿼리 => (1) 파서 => 파스된 쿼리 => 옵티마이저 => (2) 플랜생성, (3) 비용평가 => (4) 카탈로그 매니저 => 5.플랜평가 파서(Parser) 이름 그대로 파스(구문분석)을 하는 놈이다. 사용자로부터 입력받은 SQL구문이 문법적으로 오류가 있는지 검사해 준다. 옵티마이저(Optimizer) 서류 심사를 통과하면 쿼리는 옵티마이저로 전송된다. 옵티마이저는 최적화(데이터 접근법, 실행계획)를 수행하고, DBMS 두뇌의 핵심이다...
앞에서만든 백업테이블에 있는 데이터를 다시 기존테이블에 부어야할 경우, SELECT INSERT 문을 사용하면 쉽게 데이터를 넣을 수 있다.1INSERT INTO 기존테이블 SELECT * FROM 백업테이블cs 원하는 컬럼만 넣고 싶을 때는 아래와같이 하면 된다.12345INSERT INTO 기존테이블(column1, column2, column3 ...)SELECT column1, column2, column3FROM 백업테이블[WHERE ]cs 사용 예)1INSERT INTO STUDENT SELECT * FROM STUDENT_BACKcs
작업을 하다보면 테이블에 있는 데이터를 임시로 백업을 해야하는 경우가 생긴다.신규테이블을 생성하면서 기존테이블에 있는 데이터를 신규테이블로 옮기는 SQL이 존재한다. 1CREATE TABLE 신규테이블 AS SELECT * FROM 기존테이블 [WHERE 조건]cs 사용 예)1CREATE TABLE STUDENT_BACK AS SELECT * FROM STUDENT WHERE NAME LIKE '강%'cs
DBMS와 버퍼 기억장치의 분류 기억 비용 : '데이터를 저장하는데 소모되는 비용' DBMS와 기억장치의 관계 DBMS는 데이터 저장을 목적으로하는 미들웨어이기 때문에 기억장치와 떨어뜨릴 수 없는 관계이다. 하디드스크(HDD) DBMS가 데이터를 저장하는 매체(저장소)는 대부분 HDD이다. 메모리 메모리는 디스크에 비해 기억 비용이 비싸기 때문에, 하드웨어 1대에 탑재할 수 있는 양이 크지 않다. DBMS는 항상 디스크 이외의 장소에도 데이터를 올려 놓는데, 바로 1차 계층의 기억장치 메모리에 올려놓는다. 버퍼를 활용한 속도 향상 DBMS가 일부라도 데이터를 메모리에 올리는 것은 성능 향상 때문이다. 한마디로 SQL 구문의 실행 속도를 빠르게 만들기 위함이다. 따라서 자주 접근하는 데이터를 메모리 위에 ..
DBMS 아키텍처한국에서는 Oracle, Micrisoft SQL Server, DB2, PostgreSQL, MySQL 등 많은 RDB가 존재하고 이러한 제품은 각각의 특징이 있다. 하지만 RDB로써 기능을 제공한다는 목적은 모두 동일하므로, 기본적인 구조 자체는 모두 같다.DBMS 내부에는 어떠한 기능이 있을까 1. 쿼리 평가 엔진사용자로부터 입력받은 SQL 구문을 분석하고, 어떤 순서로 기억장치의 데이터에 접근할지를 결정한다.=> 이때 결정되는 계획을 '실행계획'이라고 함, 데이터에 접근하는 방법을 '접근 메서드(access method)'라고 함한마디로 쿼리 평가 엔진은 계획을 세우고 실행하는 DBMS의 핵심 기능을 담당하는 모듈이다. 2. 버퍼 매니저DBMS는 버퍼라는 특별한 용도로 사용하는 메..