逗号分隔列表的Mysql WHERE问题

标签 mysql sql denormalized

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

在 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/

相关文章:

database - NOSQL 反规范化数据模型

php - 在数据库中存储数组

mysql - 按子查询生成的列的值过滤(Mysql)

mysql - 具有条件的 MySQL 中 Row 中的值总和

php - 选择最高和最低日期

PHP - MySQL 到 PDO

mysql - 在mysql数据库中搜索代码

sql - 如何在 MySQL 中执行 FULL OUTER JOIN?

sql - 使用 SQL 列出 Postgres db 8.1 中的所有序列