[sql] SQL 테이블 생성 시 인덱스 설정하기

인덱스는 데이터베이스에서 테이블의 검색 속도를 향상시키는데 사용되는 강력한 기능입니다. 특히 대용량 데이터베이스에서 데이터를 효율적으로 검색하고 정렬할 수 있도록 도와줍니다.

SQL에서 테이블을 생성할 때 인덱스를 설정하는 방법에 대해 알아보겠습니다.

1. UNIQUE 인덱스 설정하기

UNIQUE 인덱스는 테이블에서 중복된 값을 허용하지 않는 열을 지정하는데 사용됩니다. CREATE TABLE 문의 열 정의에서 UNIQUE 키워드를 사용하여 인덱스를 설정할 수 있습니다. 예를 들어, users 테이블에서 email 열에 UNIQUE 인덱스를 설정하려면 다음과 같이 작성할 수 있습니다:

CREATE TABLE users (
   id INT PRIMARY KEY,
   username VARCHAR(50),
   email VARCHAR(100) UNIQUE,
   ...
);

2. PRIMARY KEY 인덱스 설정하기

PRIMARY KEY 인덱스는 테이블의 기본 키 열을 지정하는데 사용됩니다. 테이블에서 기본 키 열은 중복되지 않으며 NULL 값을 가질 수 없습니다. CREATE TABLE 문의 열 정의에서 PRIMARY KEY 키워드를 사용하여 인덱스를 설정할 수 있습니다. 예를 들어, users 테이블에서 id 열을 기본 키로 지정하려면 다음과 같이 작성할 수 있습니다:

CREATE TABLE users (
   id INT PRIMARY KEY,
   username VARCHAR(50),
   email VARCHAR(100),
   ...
);

3. 인덱스 생성 후 설정하기

테이블 생성 후에도 인덱스를 설정할 수 있습니다. CREATE INDEX 문을 사용하여 인덱스를 생성하고 ALTER TABLE 문을 사용하여 테이블에 인덱스를 추가할 수 있습니다.

CREATE INDEX idx_email ON users(email);

ALTER TABLE users ADD CONSTRAINT fk_user_id FOREIGN KEY (user_id) REFERENCES users(id);

4. DROP 인덱스 해제하기

인덱스를 해제하려면 DROP INDEX 문을 사용합니다. 이를 통해 테이블에서 인덱스를 삭제할 수 있습니다.

DROP INDEX idx_email ON users;

위에서는 SQL 테이블 생성 시 인덱스를 설정하는 방법에 대해 알아보았습니다. 인덱스를 적절하게 설정하면 데이터베이스의 성능을 향상시킬 수 있으므로, 테이블을 생성할 때 인덱스를 고려하는 것이 좋습니다.

더 자세한 내용은 다음 참고 자료를 확인해주세요: