MySQL中LOCATE()和FIND_IN_SET()函数有什么区别?
我们知道,这两个函数都用于在提供的参数中搜索字符串,但它们之间有一些显著的差异,具体如下。
- FIND_IN_SET()函数使用字符串列表,该列表本身是一个包含由逗号分隔的子字符串的字符串。而LOCATE()函数包含一个字符串,从中查找第一个匹配的子字符串的位置(如果存在)。
- 在LOCATE()函数中,我们可以通过提供一个可选参数来管理搜索的起始点。而对于FIND_IN_SET()函数,MySQL不提供这种灵活性,搜索将从第一个字符串默认开始。
- 对于整数而言,FIND_IN_SET()函数比LOCATE()函数更适合。可以通过以下示例来理解
阅读更多:MySQL 教程
示例
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。
极客教程