## MySQL 패턴 매칭: LIKE vs. LOCATE: 어느 것이 더 빠릅니까?

DDD
풀어 주다: 2024-10-25 07:51:29
원래의
221명이 탐색했습니다.

##  MySQL Pattern Matching: LIKE vs. LOCATE: Which is Faster?

패턴 일치에 대한 MySQL LIKE와 LOCATE의 성능 비교

MySQL은 문자열에 대한 패턴 일치 작업을 수행하기 위한 두 가지 기본 함수인 LIKE와 LOCATE를 제공합니다. 위치하고 있다. 둘 다 비슷한 목적으로 사용되지만 쿼리 효율성에 영향을 미칠 수 있는 성능 특성에 미묘한 차이가 있습니다.

LIKE 연산자는 와일드카드 문자(%)를 사용하여 문자열 내의 패턴을 일치시킵니다. 예:

<code class="sql">SELECT * FROM table WHERE column LIKE '%text%';</code>
로그인 후 복사

반면에 LOCATE 함수는 문자열 내에서 특정 하위 문자열이 처음 나타나는 위치를 검색하고 해당 위치를 반환합니다. 0이 아닌 결과는 일치함을 나타냅니다.

<code class="sql">SELECT * FROM table WHERE LOCATE('text', column) > 0;</code>
로그인 후 복사

이 두 함수의 성능을 비교할 때 일반적으로 LIKE 연산자가 LOCATE보다 약간 더 빠르게 수행되는 것으로 관찰됩니다. 이는 주로 LIKE가 일치 항목이 있는지 확인하기 위해 추가 비교('> 0")가 필요하지 않기 때문입니다.

이 차이점을 설명하기 위해 다음 벤치마크 결과를 고려해 보겠습니다.

mysql> SELECT BENCHMARK(100000000,LOCATE('foo','foobar')); +---------------------------------------------+ | BENCHMARK(100000000,LOCATE('foo','foobar')) | +---------------------------------------------+ | 0 | +---------------------------------------------+ mysql> SELECT BENCHMARK(100000000,LOCATE('foo','foobar') > 0); +-------------------------------------------------+ | BENCHMARK(100000000,LOCATE('foo','foobar') > 0) | +-------------------------------------------------+ | 0 | +-------------------------------------------------+ mysql> SELECT BENCHMARK(100000000,'foobar' LIKE '%foo%'); +--------------------------------------------+ | BENCHMARK(100000000,'foobar' LIKE '%foo%') | +--------------------------------------------+ | 0 | +--------------------------------------------+

위 내용은 ## MySQL 패턴 매칭: LIKE vs. LOCATE: 어느 것이 더 빠릅니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿