목록DB (25)
송민준의 개발노트
보호되어 있는 글입니다.
보호되어 있는 글입니다.
오라클만 쓰다가 몇년 만에 MySql을 쓸라니 헷갈려서 남김. - 설치 방법은 생략 - 설치 후 1. 환경변수 설정 - MySql이 설치된 경로의 bin 경로를 찾는다. ex ) C:\Program Files\MySQL\MySQL Server 8.0\bin - 내PC -> 속성 -> 고급 시스템 설정 -> 고급탭 ->환경 변수 -> 시스템 변수 -> Path를 찾고 편집 클릭 -> 새로만들기 -> 경로 복붙하고 확인하면 어디서든 접근 가능함 2. cmd에 들어감 // root 계정으로 접속함 mysql -u root -p // 비번 입력 후 // 타임존부터 세팅 set time_zone 'Asia/Seoul'; // 유저 생성 create user 'scott'@'%' identified by 'test..
시작일 : 20201001 가정 종료일 : 20201031 가정 SELECT TO_CHAR(TRUNC(TO_DATE('20201001'), 'DD') + LEVEL - 1, 'YYYYMMDD') DAYS FROM DUAL CONNECT BY LEVEL
데이터를 다루다가 어느 순간부터 특정 테이블 쿼리가 느려지기 시작했다. 5개 정도 테이블을 조인 걸어서 조회하는 것이였는데... 실행계획이 이상하게 잡혔나싶어서 보니 정상적이다... 인덱스도 바뀐게 없는데...!!? 이리저리 힌트 바꿔가면서 삽질해봤지만 10초 정도 시간 줄이는게 끝... 물론 쿼리도 개선해야 할 부분이 있었다. 필요없는 칼럼들이 포함되어 있고 조건절에 'exists'가 아닌 'in'으로만 이루어져 있고... 하지만 더 좋은 방법이 있었다. Analyze를 사용하는 것이었다. Analyze란 무엇일까? - 인덱스, 테이블, 클러스터의 통계정보를 생성한다. 생성된 정보들은 비용기준의 옵티마이저가 가장 효율적인 실행계획을 수립하기 위해 최소비용을 계산할 때 사용된다. 구조를 확인하는 것은 물..
옵티마이저란? - 가장 빠르고 효율적인 SQL 실행 계획을 수립하고 SQL을 실행하는 DBMS의 핵심적인 소프트웨어다.. - 실행 계획은 SQL 성능에 핵심적인 역할을 하며 동일한 결과라도 계획에 따라 성능이 다르다. 옵티마이저 종류 1. 규칙 기반 옵티마이저 미리 정해 놓은 규칙(액세스 경로별 우선순위)에 따라 엑세스 경로를 평가하고 실행계획을 선택한다. 2. 비용 기반 옵티마이저 예상되는 비용(쿼리 수행에 필요한 시간)을 기반으로 최적화를 수행한다. 미리 구한 테이블과 인덱스에 대한 통계정보를 기초로 각 오퍼레이션 단계별 예상 비용을 산정하고, 총비용이 가장 낮은 계획을 선택한다.(부적절한 통계정보의 경우 성능 정하) 옵티마이저 특징 - Data Dictionary에 있는 오브젝트 통계, 시스템 통계..
파티션이란? - 기업에서 관리하는 데이터는 정말 많은 양을 다루고 있다. 그러다보면 거대한 데이터를 가지고 있는 테이블이 존재하게 되는데(Big Transaction Table) 이는 트러블슈팅이 발생될 경우 심각한 악영향을 미칠 수 있다. - 이러한 악영향을 예방 및 피해를 줄이고 효율적으로 관리하기 위해 테이블을 작은 단위로 나누는 것을 말한다. 파티션의 기능 정의 - 파티션은 대용량의 테이블을 여러개의 데이터 파일로 분리해 저장하는 것을 말한다. - 테이블의 데이터가 물리적으로 분리되어 데이터 파일에 저장되면 CRUD 수행의 성능이 향상된다. - 파티션은 각각 파티션 별로 독립적으로 관리될 수 있다. (파티션 별 백업, 복구 및 인덱스 생성 등) - 파티션은 Oracle DB의 논리적 단위인 테이블..
비율을 계산해주는 함수는 다음과 같다. 1. CUME_DIST 2. PERCENT_RANK 3. NTILE 4. RATIO_TO_REPORT 1. CUME_DIST - 파티션 전체 건수에서 현재 행보다 작거나 같은 건수에 대해 누적 백분율을 계산해주며 0과 1사이에 값이 분포해있다. select deptno, ename, sal, cume_dist() over(order by sal desc) as c_s from emp; 위 쿼리를 실행하면 백분율 처럼 나온다. 과거 학창시절 성적 백분율 나오는 그런거... 2. PERCENT_RANK - ANSI/ISO SQL 표준과 Oracle DBMS에서 지원해준다. - 파티션에서 제일 먼저 나온 것을 0, 제일 늦게 나온 것을 1로 하여 값이 아닌 행의 순서별 ..