MySQL利用GROUP_CONCAT将一对多关系把子表某一字段拼成一行返回主表中

主表master

  @ApiModelProperty("主表主键id")private String id;@ApiModelProperty("姓名")private String name;

子表slave

  @ApiModelProperty("子表主键id")private String id;@ApiModelProperty("主表主键id")private String masterId;@ApiModelProperty("行为")private String active;

第一步将子表数据归为一行

SELECT masterId, GROUP_CONCAT(active) 
FROM `slave`
GROUP BY masterId

 

第二步联合主表 

SELECTm.*,s.actives 
FROM`master` m
LEFT JOIN ( SELECT masterId, GROUP_CONCAT( active ) actives FROM `slave` GROUP BY masterId ) s 
ON m.id = s.masterId

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部