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 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现

mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现

mysql 查询某字段中以逗号分隔的字符串的包含查询和关联查询实现

php 如何从mysql输出数组用逗号分隔?