码迷,mamicode.com
首页 > 数据库 > 详细

MYSQL A、B表数组关联查询

时间:2019-07-29 09:52:36      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:分组   mamicode   nbsp   表数   结果   sel   通过   数据库   关联   

最终结果:

技术图片


 

数据库表

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 A、B表数组关联查询

标签:分组   mamicode   nbsp   表数   结果   sel   通过   数据库   关联   

原文地址:https://www.cnblogs.com/zhcblog-20181026/p/11261665.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!