>  기사  >  데이터 베이스  >  ## InnoDB를 사용하여 MySQL LIKE \'%string%\' 쿼리를 어떻게 최적화할 수 있나요?

## InnoDB를 사용하여 MySQL LIKE \'%string%\' 쿼리를 어떻게 최적화할 수 있나요?

Linda Hamilton
Linda Hamilton원래의
2024-10-25 06:22:02615검색

## How Can I Optimize MySQL LIKE '%string%' Queries with InnoDB?

InnoDB

에서 MySQL LIKE '%string%' 쿼리 최적화

많은 애플리케이션에서는 텍스트 본문 내에서 문자열을 검색해야 합니다. MySQL은 이러한 검색을 수행하기 위해 LIKE 연산자를 제공하지만 최적의 성능을 위해 이러한 쿼리를 어떻게 최적화할 수 있습니까?

문제

다음 표를 고려하세요.

<code class="sql">CREATE TABLE `example` (
`id` int(11) unsigned NOT NULL auto_increment,
`keywords` varchar(200) NOT NULL,
PRIMARY KEY  (`id`)
) ENGINE=InnoDB;</code>

다음과 같은 쿼리를 실행할 때

<code class="sql">SELECT id FROM example WHERE keywords LIKE '%whatever%'</code>

데이터베이스가 검색 속도를 높이기 위해 인덱스를 사용할 것으로 예상할 수 있습니다. 그러나 다음을 사용하여 키워드 열에 간단한 인덱스를 추가하면

<code class="sql">ALTER TABLE `example` ADD INDEX `idxSearch` (`keywords`);</code>

EXPLAIN 쿼리는 MySQL이 여전히 전체 테이블을 스캔해야 함을 나타냅니다.

해결책

MySQL은 검색 문자열의 시작 부분을 일치시켜 인덱스를 사용합니다. LIKE 'whatever%'와 같은 쿼리의 경우 'whatever'가 문자열 시작 부분에 고정되어 있으므로 인덱스를 사용할 수 있습니다.

그러나 LIKE '%whatever%'와 같은 쿼리에는 이러한 앵커가 없습니다. 검색어는 문자열 내에서 "떠다니는" 것으로 나타나 MySQL이 전체 필드를 검색하도록 합니다.

이러한 쿼리를 최적화하기 위해 전체 텍스트 인덱스를 사용할 수 있습니다. 이러한 색인은 "부동" 검색을 위해 특별히 설계되었습니다. InnoDB는 버전 5.6.4부터 전체 텍스트 인덱스를 지원하여 LIKE '%string%' 쿼리를 최적화하기 위한 실행 가능한 옵션이 되었습니다.

위 내용은 ## InnoDB를 사용하여 MySQL LIKE \'%string%\' 쿼리를 어떻게 최적화할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.