在MySQL中,FIELD()函数与FIND_IN_SET()函数有何不同?
众所周知,这两个函数都用于从它们提供的参数中搜索字符串,但是它们之间有一些明显的区别,如下所示:
FIND_IN_SET()- 函数使用字符串列表,字符串列表本身就是一个包含用逗号分隔的子字符串的字符串。而FIELD()function包含不同字符串的列表,它将在其中找到要搜索的字符串的索引号(如果存在)。
FIND_IN_SET()- 如果任何参数(即搜索字符串或字符串列表)为NULL,则函数返回NULL。相反,FIELD()函数不返回NULL,但如果搜索字符串为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)热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短