一个字段同时查询几个不同值的SQL

搜索用户名中含有 user 或者 admin 的所有用户:


SELECT * FROM user WHERE username LIKE '%user%' OR username LIKE '%admin%'



mysql中使用FIND_IN_SET查询在逗号隔开的字符串中符合多个ID的数据

FIND_IN_SET(str,strlist)函数   它不同于 like 模糊查询,它是以“,”来分隔值

str 要查询的字符串

strlist 字段名 参数以”,”分隔 如 (1,2,6,8)

查询字段(strlist)中包含(str)的结果,返回结果为null或记录

下面举例说明

test表中有如下字段及值

下面我想查询area中包含”1″这个参数的记录

SELECT * from test where FIND_IN_SET('1',area)

返回值

下面查询btype字段中包含”15″这个参数的值

SELECT * from test where FIND_IN_SET('15',btype)

返回值


FIND_IN_SET和like的区别

like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果。


你可能感兴趣的:(php,MY,SQL)