>  기사  >  데이터 베이스  >  ## InnoDB에서 MySQL LIKE \'%string%\' 쿼리를 어떻게 효율적으로 만들 수 있나요?

## InnoDB에서 MySQL LIKE \'%string%\' 쿼리를 어떻게 효율적으로 만들 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-25 07:23:29721검색

## How Can I Make MySQL LIKE '%string%' Queries Efficient in InnoDB?

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

문제 설명

InnoDB 테이블의 쿼리에서 LIKE '%string%' 절을 사용할 때 'keywords' 열의 인덱스가 무효화되어 전체 테이블 스캔이 발생하는 것이 관찰됩니다.

해결책

InnoDB 인덱스는 인덱스 열의 시작 부분에서 시작하는 문자열 비교에 최적화되어 있습니다. 그러나 LIKE '%string%' 절을 사용하면 검색어가 열의 어느 위치에나 나타날 수 있습니다. 이러한 유형의 쿼리는 검색어가 문자열 시작 부분에 고정되어 있지 않기 때문에 시작 기반 인덱스를 사용할 수 없습니다.

최적 솔루션으로서의 전체 텍스트 인덱스

최적화하려면 InnoDB의 부동 검색어를 포함하는 쿼리에는 전체 텍스트 인덱스를 사용해야 합니다. 전체 텍스트 인덱스는 유연한 문자열 일치를 허용하므로 이러한 쿼리를 처리하도록 특별히 설계되었습니다.

MySQL 5.6.4 이상으로 업그레이드

전체 텍스트 인덱스에 대한 InnoDB 지원은 MySQL 5.6.4에서 도입되었습니다. MySQL 버전이 5.6.4 미만인 경우 이 기능을 활용하려면 업그레이드하는 것이 좋습니다. MySQL 5.6.4 이상으로 업그레이드하면 전체 텍스트 인덱스를 사용하여 InnoDB에서 LIKE '%string%' 쿼리를 최적화할 수 있습니다.

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

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