0712-2888027 189-8648-0214
微信公众号

孝感风信网络科技有限公司微信公众号

当前位置: 主页 > 技术支持 > MySQL > 利用MySQL中FIND_IN_SET函数进行字段中包含某字符串条件查询

利用MySQL中FIND_IN_SET函数进行字段中包含某字符串条件查询

时间:2018-01-22来源:风信网 点击:
风信建站在实际的项目开发中,需要针对数据库表中某一个字段进行多条件查询
字段信息如下:

利用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的条件,同时满足多个条件的查询需求。

风信建站承接企业网站二次开发,可满足企业根据量身定制的需求,针对性开发适合企业自身的产品,帮助企业完善互联网产品提供技术支持,如您有二次开发需求或企业建站改版等需求服务可与我们联系,服务热线:18986480214。
栏目列表
推荐内容
热点内容
展开