색인은 열에 특정 값이 있는 행을 빠르게 찾는 데 사용됩니다.
인덱스를 사용하지 않으면 MySQL은 레코드 1에서 시작한 다음 관련 행을 찾을 때까지 전체 테이블을 읽어야 합니다. 테이블이 클수록 시간이 더 걸립니다. 테이블의 쿼리된 열에 인덱스가 있으면 MySQL은 모든 데이터를 볼 필요 없이 데이터 파일의 중간을 검색하는 지점에 빠르게 도달할 수 있습니다.
물론 인덱스를 너무 많이 작성하는 것은 쉽지 않습니다. 인덱스를 많이 작성할수록 수정 속도가 느려집니다. 수정된 데이터를 쓸 때 인덱스도 수정해야 하기 때문입니다.
인덱스는 클러스터형 인덱스와 비클러스터형 인덱스로 구분됩니다. 클러스터형 인덱스는 데이터 저장 위치에 따라 정렬되지만 비클러스터형 인덱스는 행 검색 속도가 많이 다릅니다. 비클러스터형 인덱스는 단일 행 검색의 경우 빠릅니다.
1. 🎜>가장 기본적인 인덱스입니다. 예를 들어 위의 제목 필드에 대해 생성된 인덱스는 MyIASM의 기본 BTREE 유형 인덱스이기도 하며 대부분의 경우에 사용됩니다. .
– 인덱스 직접 생성
CREATE INDEX index_name ON table(column(length)) –修改表结构的方式添加索引 ALTER TABLE table_name ADD INDEX index_name ON (column(length)) –创建表的时候同时创建索引 CREATE TABLE `table` ( `id` int(11) NOT NULL AUTO_INCREMENT , `title` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL , `time` int(10) NULL DEFAULT NULL , PRIMARY KEY (`id`), INDEX index_name (title(length)) )
– 인덱스 삭제
DROP INDEX index_name ON table
는 인덱스 열의 값이 고유해야 한다는 점을 제외하면 일반 인덱스와 유사하지만 null 값입니다. 허용됩니다(기본 키와 기본 키는 다릅니다). 결합 인덱스인 경우 컬럼 값의 조합은 유일해야 하며, 생성 방법은 일반 인덱스와 유사하다.
–创建唯一索引 CREATE UNIQUE INDEX indexName ON table(column(length)) –修改表结构 ALTER TABLE table_name ADD UNIQUE indexName ON (column(length)) –创建表的时候直接指定 CREATE TABLE `table` ( `id` int(11) NOT NULL AUTO_INCREMENT , `title` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL , `time` int(10) NULL DEFAULT NULL , PRIMARY KEY (`id`), UNIQUE indexName (title(length)) );3. 전체 텍스트 인덱스(FULLTEXT)
MySQL은 버전 3.23부터 전체 텍스트 인덱싱 및 전체 텍스트 검색을 지원합니다. 23. FULLTEXT 인덱스는 MyISAM 테이블에만 사용할 수 있습니다. CREATE TABLE 문의 일부로 CHAR, VARCHAR 또는 TEXT 열에서 생성하거나 나중에 ALTER TABLE 또는 CREATE INDEX를 사용하여 추가할 수 있습니다. ////더 큰 데이터 세트의 경우 FULLTEXT 인덱스 없이 테이블에 데이터를 입력한 다음 인덱스를 생성하는 것이 기존 FULLTEXT 인덱스에 데이터를 입력하는 것보다 빠릅니다. 그러나 대용량 데이터 테이블의 경우 전체 텍스트 인덱스를 생성하는 것은 시간과 하드 디스크 공간을 많이 소모하는 프로세스라는 점을 기억하십시오.
– 전체 텍스트 인덱스 추가에 적합한 테이블 생성
CREATE TABLE `table` ( `id` int(11) NOT NULL AUTO_INCREMENT , `title` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , `content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL , `time` int(10) NULL DEFAULT NULL , PRIMARY KEY (`id`), FULLTEXT (content) );
ALTER TABLE article ADD FULLTEXT index_content(content)
CREATE FULLTEXT INDEX index_content ON article(content)
일반적으로 사용되는 SQL 쿼리문은 제한 사항이 많기 때문에 MySQL의 효율성을 더욱 짜기 위해서는 결합 인덱스 구축을 고려할 필요가 있습니다. 예를 들어 위 테이블에서는 제목과 시간에 대한 결합 인덱스가 생성됩니다. ALTER TABLE 기사 ADD INDEX index_titme_time(제목(50), 시간(10)). 이러한 결합지수를 구축하는 것은 실제로 다음과 같은 두 개의 결합지수를 구축하는 것과 같습니다.
–제목, 시간
–제목
왜 시간과 같은 결합지수는 없는 걸까요? ? 모직물? 이는 MySQL 복합 인덱스의 "가장 왼쪽 접두사"의 결과입니다. 간단한 이해는 가장 왼쪽부터 조합을 시작하는 것입니다. 이 두 열을 포함하는 쿼리뿐만 아니라 다음 SQL에 표시된 대로 결합된 인덱스를 사용합니다.
– 위 인덱스 사용
SELECT * FROM article WHREE title='测试' AND time=1234567890; SELECT * FROM article WHREE utitle='测试';
– 사용하지 않음 위의 색인을 사용하세요
SELECT * FROM article WHREE time=1234567890;