MySQL 的 LOCATE() 函数和 FIND_IN_SET() 函数有什么区别?


众所周知,这两个函数都用于在提供的参数中搜索字符串,但它们之间存在一些显著的区别,如下所示:

  • FIND_IN_SET() 函数使用字符串列表,该列表本身就是一个字符串,其中子字符串用逗号分隔。而 LOCATE() 函数包含一个字符串,它将从中查找子字符串(如果存在)的第一次出现的的位置。
  • 在 LOCATE() 函数中,我们可以通过提供一个可选的位置参数来管理搜索的起点。而对于 FIND_IN_SET() 函数,MySQL 没有提供这种灵活性,搜索默认从第一个字符串开始。
  • 对于整数,FIND_IN_SET() 比 LOCATE() 函数更合适。可以通过以下示例理解这一点。

示例

mysql> Select IF(LOCATE(2,'10,11,12,13') > 0,1,0) As result;
+--------+
| result |
+--------+
|      1 |
+--------+
1 row in set (0.05 sec)

mysql> Select IF(FIND_IN_SET(2,'10,11,12,13') > 0,1,0)As Result;
+--------+
| Result |
+--------+
|      0 |
+--------+
1 row in set (0.00 sec)

从上面的示例结果集可以看出,即使 2 作为字符串不存在于参数中,LOCATE() 函数也会返回 1。但 FIND_IN_SET() 函数返回 0,这是正确的答案。

更新于:2020年2月3日

453 次浏览

开启你的职业生涯

完成课程获得认证

开始学习
广告