Mysql WHERE问题以逗号分隔列表

我需要帮助解决这个问题.

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卸载环境查看是否已安装MySQL卸载mysql服务查看是否...
目录数据类型数据类型分类数值类型以TINYINT认识整型族有符号...
目录表的约束空属性非空约束(NOT NULL Constraint)默认值定...
目录函数时间日期函数:字符串函数数学函数其他函数 函数 时间...
目录使用C语言连接库的安装C APImysql_initmysql_real_conne...
目录用户用户管理查询所有用户查看当前用户查看当前连接数创...