您的位置:首頁/技術文章
文章詳情頁

關于mysql聯合查詢一對多的顯示結果問題

瀏覽:125日期:2022-06-18 11:02:46

問題描述

有兩張表,一張是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`

相關文章:
国产综合久久一区二区三区