mysql 如何匹配多个 like 条件?

有一个tag表:

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

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

阅读 7.3k
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函数了解下

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题