我需要帮助解决这个问题.
在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的外键)