在 MySQL 中,FIELD() 函数与 FIND_IN_SET() 函数有何不同?
mysqlmysqli database
众所周知,这两个函数都用于从它们提供的参数中搜索字符串,但它们之间存在一些显著差异,如下所示 −
FIND_IN_SET() − 函数使用字符串列表,该列表本身是一个包含逗号分隔的子字符串的字符串。而 FIELD() 函数包含不同字符串的列表,它将在其中找到要搜索的字符串(如果存在)的索引号。
如果任何参数(即搜索字符串或字符串列表)为 NULL,FIND_IN_SET() − 函数将返回 NULL。相反,如果搜索字符串为 NULL,FIELD() 函数不会返回 NULL,而是返回 0。
示例
mysql> Select FIND_IN_SET(NULL,'Ram is a good boy') AS Result; +--------+ | Result | +--------+ | NULL | +--------+ 1 row in set (0.00 sec) mysql> SELECT FIND_IN_SET('RAM',NULL)AS RESULT; +--------+ | RESULT | +--------+ | NULL | +--------+ 1 row in set (0.00 sec) mysql> Select FIELD(NULL,'Ram','is','good','boy'); +-------------------------------------+ | FIELD(NULL,'Ram','is','good','boy') | +-------------------------------------+ | 0 | +-------------------------------------+ 1 row in set (0.00 sec)