전체 글

· [DB] ORACLE
Oracle Statspack은 Oracle Database에 대한 resource 사용량분석 성능문제 분석을 위해 사용되는 툴이다. awrrpt를 사용하는것이 편리하나 awr의 경우 Oracle Enterprise Edition을 사용하더라도 Diagnostic Pack이 포함되어 있지 않으면 원칙적으로는 사용이 불가하다. 따라서 Diagnostick Pack을 구매하지 않은 경우 Awrrpt 기능응 사용할 수 없으나 statspack은 무료로 사용이 가능하다. 1. Statpack을 구성하는 scriptSpcreate.sql : statspack 설치 scriptSpreprot.sql : statspack reporting scriptSpdoc.txt : 영문 사용자 메뉴얼Sppurge.sql : d..
COLLATION 확인Collation 종류 보기SELECT * FROM ::fn_helpcollations() --DB CollationSELECT SERVERPROPERTY('collation') --DB Collation ListSELECT name, collation_name FROM sys.databases;--Column Collation ListSELECT name, collation_name FROM sys.columns COLLATION 변경--DB Collation 변경ALTER DATABASE CollateDb COLLATE Korean_Wansung_CI_AI GO --Table Column Collation 이 다를 경우--"칼럼 'xxx'는 데이터베이스 데이타 정렬에 종속되어 ..
SQL Server 인스턴스 내에 있는 모든 데이터베이스(또는 테이블)의 이름을 반환하며 이 이름을 참조하여 지정된 반복문을 수행 한다. sp_MSforeachdb구문exec sp_MSforeachdb 'use [?] select * from sys.database_files' 결과 예시 sp_MSforeachtable구문exec sp_MSforeachtable 'select count(*) from ?' 결과예시 출처: https://iheedol.tistory.com/entry/spMSforeachdb-spMSforeachtable [iHeedol:티스토리]
Version : SQL Server 2000, 2005, 2008, 2008R2, 2012 Fill Factor 옵션은 SQL Server에서 인덱스를 생성 할 때 각 페이지를 얼마나 채울지 지정하는 옵션이다. 대부분의 사용자들은 Fill Factor에 대한 정의는 잘 알고 있으나 몇 가지 사실에 대해서는 많이들 오해하는 부분이 있어 간단히 정리해 보고자 한다. Fill Factor 의 기본값은 100 이다?Fill Factor의 기본값은 0 이다. 사실 0과 100은 동일한 기능으로 작동 한다. Fill Factor의 옵션을 80으로 지정하면 80%의 비율로 채우기를 한다. 이미 생성된 인덱스에 Fill Factor 옵션을 변경하면 자동으로 적용 된다?Fill Factor의 비율에 따른 분할은 인덱스..
A. 사용자 쿼리에 대해 예상되는 개선 사항이 가장 높은 누락된 인덱스 10개 찾기SELECT TOP 10 * FROM sys.dm_db_missing_index_group_stats ORDER BY avg_total_user_cost * avg_user_impact * (user_seeks + user_scans) DESC; B. 특정 누락된 인덱스 그룹의 개별 누락된 인덱스 및 해당 열 정보 찾기SELECT migs.group_handle, mid.* FROM sys.dm_db_missing_index_group_stats AS migs INNER JOIN sys.dm_db_missing_index_groups AS mig ON (migs.group_handle = mig.index_..
· DBA
인덱스 데이터베이스에서 인덱스 없이 검색하려면, 테이블을 처음부터 끝까지 모두 읽어야한다. 반면, 인덱스를 이용하면 일부만 읽고 멈출 수 있다. 범위 스캔(Range Scan)이 가능하며 가능한 이유는 인덱스는 정렬 돼있기 때문이다. ​DBMS는 일반적으로 B-Tree 인덱스를 사용한다. 상단에 Root 블록, 중간에 Branch 블록, 맨 아래 Leaf 블록이 있다.루트와 브랜치 블록에 있는 각 레코들은 하위 블록에 대한 주소값을 갖는다.루트와 브랜치 블록엔 키값을 갖지 않는 특별한 레코드가 있다. 이를 'LMC'라고 하며 'Leftmost Child'의 줄임말이다. LMC는 자식 노드 중 가장 왼쪽 끝에 위치한 블록을 가리킨다. LMC가 가리키는 주소로 찾아간 블록에는 키 값을 가진 첫 번째 레코드보..
mewoni
Mewoni's DB World