加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql WHERE问题以逗号分隔列表

发布时间:2020-12-11 23:37:52 所属栏目:MySql教程 来源:网络整理
导读:我需要帮助解决这个问题. 在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,则

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

在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的外键)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读