mysql字符串查找函数

 

FIND_IN_SET(str,strlist)

假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在1 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则   FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist strlist 为空字符串,则返回值为0。如任意一个参数为NULL,则返回值为NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。返回值为strstrlist中的位置,从1开始计数。

LOCATE(substr,str)

POSITION(substr IN str)

 

函数返回子串substr在字符串str中第一次出现的位置。如果子串substrstr中不存在,返回值为0

str IN (strlist)

查找strstrlist中出现的位置。如果找不到,返回falsestrlist为一个用逗号连接的字符串。

函数的区别为:第一个函数FIND_IN_SET中的strlist为一个用逗号连接起来的字符串,一般为数据库中的某个字段。当需要查找某个字段中是否有某个值的时候,使用这个函数。

第三个函数IN()刚好和函数FIND_IN_SET()相反,strlist为一个常量字符串序列,str为数据库中某个字段。此时查找数据库中的字段是否在某个序列中。

第二个函数为字符串查找函数,类似于php中的strpos()函数,或者javascript中的charAt()函数。此函数可以完成以上两个函数的功能。

猜你喜欢

转载自duchengjiu.iteye.com/blog/2034410