MySQL에서 INDEX와 KEY 사용
소개
MySQL은 인덱스 생성을 위한 두 가지 구문을 제공합니다. 테이블: INDEX 및 KEY. 둘 다 동일한 기능을 달성하지만 미묘한 차이가 있습니다.
동의어와 확장자
INDEX와 KEY의 주요 차이점은 특성에 있습니다. INDEX는 ISO SQL 호환 용어로 간주되는 반면 KEY는 MySQL 관련 확장입니다. 즉, INDEX를 사용하면 다양한 데이터베이스 시스템 간 이식성이 보장되는 반면 KEY는 MySQL로 제한됩니다.
사용
그러나 실제로 INDEX와 KEY의 사용은 다음과 같습니다. 상호 교환 가능. 둘 다 빠른 조회를 제공하여 쿼리 성능을 향상시키기 위해 열에 인덱스를 생성합니다. 다음 예에서 볼 수 있듯이 사용법 구문은 동일합니다.
CREATE TABLE tasks ( task_id int unsigned NOT NULL AUTO_INCREMENT, parent_id int unsigned NOT NULL DEFAULT 0, task varchar(100) NOT NULL, date_added timestamp NOT NULL, date_completed timestamp NULL, PRIMARY KEY (task_id), KEY parent (parent_id) -- or INDEX parent (parent_id) )
기본 키 고려 사항
INDEX와 KEY는 인덱스 생성에 서로 바꿔 사용할 수 있습니다. , 기본 키를 처리할 때 예외가 있습니다. PRIMARY KEY 키워드는 다른 데이터베이스 시스템과의 호환성을 위해 열 정의에서 KEY로 축약될 수 있습니다. 예:
CREATE TABLE orders ( order_id int PRIMARY KEY, order_date timestamp );
이 경우 KEY는 PRIMARY KEY의 동의어이며 테이블의 각 행을 고유하게 식별하는 order_id 열에 고유 인덱스를 생성합니다.
결론
요약하면 INDEX와 KEY는 모두 동일한 용도로 사용되지만 INDEX가 선호됩니다. ISO SQL 준수로 인해. 그러나 대부분의 실제 시나리오에서 둘 중 하나를 선택하는 것은 개인적인 선호도 또는 특정 표준 준수의 문제입니다. 사용법과 사용되는 컨텍스트의 차이를 이해하면 데이터베이스 성능을 효과적으로 최적화하는 데 도움이 됩니다.
위 내용은 MySQL의 INDEX와 KEY: 차이점은 무엇이며 어느 것을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!