PostgreSQL-INDEXES
인덱스는 데이터베이스 검색 엔진이 데이터 검색 속도를 높이는 데 사용할 수있는 특수 조회 테이블입니다. 간단히 말해서 인덱스는 테이블의 데이터에 대한 포인터입니다. 데이터베이스의 색인은 책 뒷면의 색인과 매우 유사합니다.
예를 들어, 특정 주제를 다루는 책의 모든 페이지를 참조하려면 먼저 모든 주제를 알파벳순으로 나열한 색인을 참조한 다음 하나 이상의 특정 페이지 번호를 참조해야합니다.
인덱스는 SELECT 쿼리 및 WHERE 절의 속도를 높이는 데 도움이됩니다. 그러나 UPDATE 및 INSERT 문을 사용하면 데이터 입력 속도가 느려집니다. 인덱스는 데이터에 영향을주지 않고 생성하거나 삭제할 수 있습니다.
인덱스 생성에는 인덱스의 이름을 지정하고, 테이블과 인덱싱 할 열을 지정하고, 인덱스가 오름차순인지 내림차순인지 표시 할 수있는 CREATE INDEX 문이 포함됩니다.
인덱스는 인덱스가있는 열 또는 열 조합의 중복 항목을 방지한다는 점에서 UNIQUE 제약 조건과 유사하게 고유 할 수도 있습니다.
CREATE INDEX 명령
기본 구문 CREATE INDEX 다음과 같습니다-
CREATE INDEX index_name ON table_name;
인덱스 유형
PostgreSQL은 B- 트리, 해시, GiST, SP-GiST 및 GIN과 같은 여러 인덱스 유형을 제공합니다. 각 인덱스 유형은 서로 다른 유형의 쿼리에 가장 적합한 서로 다른 알고리즘을 사용합니다. 기본적으로 CREATE INDEX 명령은 가장 일반적인 상황에 맞는 B- 트리 인덱스를 생성합니다.
단일 열 인덱스
단일 열 인덱스는 하나의 테이블 열만을 기반으로 생성되는 인덱스입니다. 기본 구문은 다음과 같습니다.
CREATE INDEX index_name
ON table_name (column_name);
다중 열 인덱스
다중 열 인덱스는 테이블의 둘 이상의 열에 정의됩니다. 기본 구문은 다음과 같습니다.
CREATE INDEX index_name
ON table_name (column1_name, column2_name);
단일 열 인덱스 또는 다중 열 인덱스 생성 여부에 관계없이 쿼리의 WHERE 절에서 필터 조건으로 매우 자주 사용할 수있는 열을 고려하십시오.
열이 하나만 사용되는 경우 단일 열 인덱스를 선택해야합니다. WHERE 절에서 필터로 자주 사용되는 두 개 이상의 열이있는 경우 다중 열 인덱스가 최선의 선택입니다.
고유 인덱스
고유 인덱스는 성능뿐만 아니라 데이터 무결성에도 사용됩니다. 고유 인덱스는 테이블에 중복 값을 삽입하는 것을 허용하지 않습니다. 기본 구문은 다음과 같습니다.
CREATE UNIQUE INDEX index_name
on table_name (column_name);
부분 색인
부분 인덱스는 테이블의 하위 집합에 구축 된 인덱스입니다. 서브 세트는 조건식 (부분 인덱스의 술어라고 함)에 의해 정의됩니다. 색인에는 술어를 충족하는 테이블 행에 대한 항목 만 포함됩니다. 기본 구문은 다음과 같습니다.
CREATE INDEX index_name
on table_name (conditional_expression);
암시 적 인덱스
암시 적 인덱스는 개체가 생성 될 때 데이터베이스 서버에서 자동으로 생성되는 인덱스입니다. 기본 키 제약 조건 및 고유 제약 조건에 대해 인덱스가 자동으로 생성됩니다.
예
다음은 급여 열에 대한 COMPANY 테이블에 인덱스를 생성하는 예입니다.
# CREATE INDEX salary_index ON COMPANY (salary);
이제 다음을 사용하여 COMPANY 테이블에서 사용할 수있는 모든 인덱스를 나열하겠습니다. \d company 명령.
# \d company
이렇게하면 다음 결과가 생성됩니다. company_pkey 는 테이블이 생성 될 때 생성 된 암시 적 인덱스입니다.
Table "public.company"
Column | Type | Modifiers
---------+---------------+-----------
id | integer | not null
name | text | not null
age | integer | not null
address | character(50) |
salary | real |
Indexes:
"company_pkey" PRIMARY KEY, btree (id)
"salary_index" btree (salary)
다음을 사용하여 전체 인덱스 데이터베이스를 나열 할 수 있습니다. \di 명령-
DROP INDEX 명령
PostgreSQL을 사용하여 인덱스를 삭제할 수 있습니다. DROP명령. 성능이 느려지거나 향상 될 수 있으므로 인덱스를 삭제할 때주의해야합니다.
기본 구문은 다음과 같습니다.
DROP INDEX index_name;
다음 문을 사용하여 이전에 생성 된 인덱스를 삭제할 수 있습니다.
# DROP INDEX salary_index;
인덱스는 언제 피해야합니까?
인덱스는 데이터베이스의 성능을 향상시키기위한 것이지만 피해야하는 경우가 있습니다. 다음 지침은 인덱스 사용을 재고해야하는시기를 나타냅니다.
작은 테이블에는 인덱스를 사용하면 안됩니다.
대규모 일괄 업데이트 또는 삽입 작업이 빈번한 테이블.
많은 수의 NULL 값을 포함하는 열에는 인덱스를 사용하면 안됩니다.
자주 조작되는 열은 인덱싱하지 않아야합니다.