Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中
Posted 勿忘初心-Lislie杰
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中相关的知识,希望对你有一定的参考价值。
有两张表,
一张为爱好表b表
一张为用户表 u表
u表
id 名称 爱好Id
1 张三 1,2,3,4
2 李四 2,5
b表
id 名称
1 打乒乓
2 打羽毛球
3 打蓝球
4 上网玩游戏
5 打牌
正常查询u表
select * from u
现在需求是:
id 名称 爱好
1 张三 打乒乓,打羽毛球,打篮球,上网
2 李四 打羽毛球,打牌
修改sql为
select u.id,u.名称,group_concat(b.名称) from u left join b on find_in_set(b.id,u.爱好Id) group by u.id;
以上是关于Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中的主要内容,如果未能解决你的问题,请参考以下文章
MySQL - 如何选择表中的行,其中 id 值位于另一个表中的逗号分隔字段中?
mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现
mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现