MySQL中的FIND_IN_SET函数用于查询字段中包含某个字符串的情况
在项目开发中,需要对数据库表中的某个字段进行多条件查询
各字段分别如下:
分析该catid字段由多个值组成
需要满足的多条件查询是:满足该字段中包含158,159,160,161
我们可以利用MySQL中的FIND_IN_SET(str,strlist) 函数
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在个参数包含一个逗号(‘,’)时将无法正常运行。
编写查询的SQL语句如下:
SELECT * FROM its_company WHERE vip > 0 and (find_in_set(‘158’, catid) or find_in_set(‘159’, catid) or find_in_set(‘160’, catid) or find_in_set(‘161’, catid))
通过Where条件后面使用多个find_in_set配合or的条件,同时满足多个条件的查询需求。
文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/114936.html<