인덱스는 데이터베이스에서 테이블의 검색 속도를 향상시키는데 사용되는 강력한 기능입니다. 특히 대용량 데이터베이스에서 데이터를 효율적으로 검색하고 정렬할 수 있도록 도와줍니다.
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 테이블 생성 시 인덱스를 설정하는 방법에 대해 알아보았습니다. 인덱스를 적절하게 설정하면 데이터베이스의 성능을 향상시킬 수 있으므로, 테이블을 생성할 때 인덱스를 고려하는 것이 좋습니다.
더 자세한 내용은 다음 참고 자료를 확인해주세요: