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

mysqlmysqli database更新于 2023/11/27 18:55:00

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

  • 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)

从上述示例的结果集中,我们可以看到 LOCATE() 函数返回 1,即使参数中没有字符串,返回 2。但 FIND_IN_SET() 函数返回 0,这是正确答案。


相关文章