MySQL FIND_IN_SET的替代方案

avatar
作者
筋斗云
阅读量:0

FIND_IN_SET() 是 MySQL 函数,用于在一个以逗号分隔的字符串中查找一个值的位置

  1. 使用 LIKE 语句:
SELECT * FROM table_name WHERE concat(',', set_column, ',') LIKE '%,value,%'; 
  1. 使用 REGEXPRLIKE(这两个是等价的):
SELECT * FROM table_name WHERE set_column REGEXP '[[:<:]]value[[:>:]]'; 
  1. 使用 INSTR() 函数:
SELECT * FROM table_name WHERE INSTR(CONCAT(',', set_column, ','), CONCAT(',', 'value', ',')) > 0; 
  1. 使用 LOCATE() 函数:
SELECT * FROM table_name WHERE LOCATE('value', CONCAT(',', set_column, ',')) > 0; 
  1. 如果可能的话,修改数据库结构。将逗号分隔的字符串列更改为单独的关联表,并使用标准的 JOIN 查询。这样做的好处是查询性能更高,且易于维护。

请注意,这些替代方案可能不如 FIND_IN_SET() 性能高,尤其是在大型数据集上。在选择替代方案时,请确保它们满足您的性能需求。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!