风信建站在实际的项目开发中,需要针对数据库表中某一个字段进行多条件查询
字段信息如下:
分析该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。