MYSQL AB表数组关联查询

Posted zhcblog-20181026

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQL AB表数组关联查询相关的知识,希望对你有一定的参考价值。

最终结果:

技术图片


 

数据库表

A表:

技术图片

B表:

技术图片

 


 

操作步骤

主要关键字:FIND_IN_SET、GROUP_CONCAT、LEFT JOIN、GROUP BY

 

第一步:left join 连接AB表并通过 find_in_set  关联其ID

select us.id,us.name,us.hobbyId,hb.name hobby
from hobby hb
left join user us on find_in_set(hb.id,us.hobbyId)

 

结果:name 字段名称很多重复,做去重处理

技术图片

 

第二步:去重 GROUP BY

select us.id,us.name,us.hobbyId,hb.name hobby
from hobby hb
left join user us on find_in_set(hb.id,us.hobbyId) GROUP BY(us.name)

 

结果:这是名称已经分组了,但是 hobby 与 hobbyId 对不上

 技术图片

 

第三步:使用 GROUP_CONCAT

select us.id,us.name,us.hobbyId,GROUP_CONCAT(hb.name) hobby
from hobby hb
left join user us on find_in_set(hb.id,us.hobbyId) GROUP BY(us.name) ORDER BY us.id

 

以上是关于MYSQL AB表数组关联查询的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL 数据库2张表关联查询问题

mysql数据库,我想查a表所有的字段还有b表的某一个字段,请问我要怎么做关联查询

mysql啥时候使用子查询,啥时候使用表连接查询,关系多张表的时候该怎么查询

多个关联表多字段多条件模糊查询

mysql 三表联合查询

php中实现数据关联查询的原理是怎样的?