我需要帮助解决这个问题。
在 MYSQL 表中我有一个字段:
Field : artist_list
Values : 1,5,3,401
我需要找到艺术家 uid 401 的所有记录
我这样做
SELECT uid FROM tbl WHERE artist_list IN ('401');
我有所有记录,其中 artist_list 字段值仅为“401”,但如果我有 11,401,则此查询不匹配。
有什么想法吗?
(我不能使用 LIKE 方法,因为如果艺术家 uid 是 3(匹配 30、33、3333)...
最佳答案
短期解决方案
使用 FIND_IN_SET function :
SELECT uid
FROM tbl
WHERE FIND_IN_SET('401', artist_list) > 0
长期解决方案
规范化您的数据 - 这似乎是一个已经涉及两个表的多对多关系。逗号分隔的列表需要变成它自己的表格:
ARTIST_LIST
- artist_id(主键,ARTIST 的外键)
- uid(主键,TBL 的外键)
关于逗号分隔列表的Mysql WHERE问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3946831/