패턴 일치에 대한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!