MySQL中的FIND_IN_SET函数用于查询字段中包含某个字符串的情况

MySQL中的FIND_IN_SET函数用于查询字段中包含某个字符串的情况

在项目开发中,需要对数据库表中的某个字段进行多条件查询

各字段分别如下:

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<

(0)
运维的头像运维
上一篇2025-02-17 23:35
下一篇 2025-02-17 23:36

相关推荐

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注