关于mysql联合查询一对多的显示结果问题
问题描述
有两张表,一张是user表,一张是user_tag表
user:结构内容如下:id name age1 有马公生 182 宫园薰 16user_tag:结构内容如下:userid tagid remake1 10 10.21 20 10.31 30 10.42 20 10.3
需要在显示user列表时把tagid也要查出来
联合查询:
SELECT `user`.`id`, `user`.`name`, `user`.`age`, `user_tag`.`tagid`FROM `user`LEFT JOIN `user_tag` ON `user`.id = `user_tag`.`userid`
得到的结果是:
id name age tagid1 有马公生 18 101 有马公生 18 201 有马公生 18 302 宫园薰 16 20
这样看起来结果是重复了,如我需要显示userid=1 的结果是
1 有马公生 18 10,20,30
这种或类似的格式,sql语句该怎么写呢?实在不行只能是在程序上实现了!
问题解答
回答1:SELECT `user`.`id`, `user`.`name`, `user`.`age`, GROUP_CONCAT(`user_tag`.`tagid`)FROM `user`LEFT JOIN `user_tag` ON `user`.id = `user_tag`.`userid`GROUP BY `user`.`name`
相关文章:
1. android - 哪位大神知道java后台的api接口的对象传到前端后输入日期报错,是什么情况?求大神指点2. mac里的docker如何命令行开启呢?3. java - 在同一服务器上以不同端口启动两次同一maven项目会出错4. css - jq有无现成函数改变rotateX/Y的deg5. javascript - 如何向localStorage上的数组push数据6. java - C语言的一道算法题-兄弟郊游问题 求解?7. nginx 所有页面指向index.html8. vue添加锚点,实现滚动页面时锚点添加相应的class操作9. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?10. javascript - react-router-dom 跳转问题js
