MySQL LIKE 与 LOCATE:哪个更高效?
在 MySQL 中执行模式匹配查询时,您有两个主要选项:运算符和 LOCATE 函数。哪一种执行速度更快?
为了回答这个问题,让我们使用一个简单的基准测试来比较这两种方法的性能。以下查询使用 LIKE 运算符查找列包含特定文本的行:
SELECT * FROM table WHERE column LIKE '%text%';
以下查询使用 LOCATE 函数执行相同的操作:
SELECT * FROM table WHERE LOCATE('text',column)>0;
针对大型数据集运行这些查询表明 LIKE 运算符稍微快一些,主要是因为它避免了 LOCATE 所需的额外比较 (> 0)。以下是基准测试的结果:
mysql> SELECT BENCHMARK(100000000,LOCATE('foo','foobar')); --------------------------------------------- | BENCHMARK(100000000,LOCATE('foo','foobar')) | --------------------------------------------- | 0 | --------------------------------------------- 1 row in set (3.24 sec) mysql> SELECT BENCHMARK(100000000,LOCATE('foo','foobar') > 0); ------------------------------------------------- | BENCHMARK(100000000,LOCATE('foo','foobar') > 0) | ------------------------------------------------- | 0 | ------------------------------------------------- 1 row in set (4.63 sec) mysql> SELECT BENCHMARK(100000000,'foobar' LIKE '%foo%'); -------------------------------------------- | BENCHMARK(100000000,'foobar' LIKE '%foo%') | -------------------------------------------- | 0 | -------------------------------------------- 1 row in set (4.28 sec) mysql> SELECT @@version; ---------------------- | @@version | ---------------------- | 5.1.36-community-log | ---------------------- 1 row in set (0.01 sec)
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3