zhcblog-20181026

最终结果:


 

数据库表

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

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-11-28
  • 2021-11-23
  • 2021-11-13
  • 2021-11-30
  • 2021-12-03
猜你喜欢
  • 2021-12-08
  • 2021-12-08
  • 2022-12-23
  • 2021-11-28
  • 2021-08-05
  • 2022-12-23
相关资源
相似解决方案