mysql 如何匹配多个 like 条件?

有一个tag表:

id tag
1 a,b,c
2 a,c,d
3 a

请问如何查询 tag 里包含 a 和 c 的? 也就是第一行和第二行

阅读 7.5k
3 个回答

MySQL

SELECT * from tag_table where  FIND_IN_SET('a',tag)>0  and FIND_IN_SET('c',tag)>0;

PostgreSQL

SELECT * from tag_table where 'a' = ANY(STRING_TO_ARRAY(tag, ','))  and 'c'= ANY(STRING_TO_ARRAY(tag, ','));
select * from xxx where CONCAT(',', tag, ',') like '%,a,%' and CONCAT(',', tag, ',') like '%,c,%'

FIND_IN_SET函数了解下

推荐问题