mysql 如何合并结果?

2014-03-24 11:00:43 +08:00
 coolicer
name type
小李 2
小李 3
小李 4
mx 2
mx 4

能不能返回
name type
小李 2,3,4
mx 2,4
2004 次点击
所在节点    问与答
6 条回复
ivanlw
2014-03-24 11:20:33 +08:00
这个是用SQL语句获得结果集之后,你需要用编程语言处理的事情了(把2 3 4 append到lists或者push_back到vector),因为把234逗号隔开放到数据库里面是不符合范式的,这也是俗称的denormalised database.
coolicer
2014-03-24 11:24:19 +08:00
@ivanlw 或者是[2,3,4]
coolicer
2014-03-24 11:27:22 +08:00
@ivanlw
如果我直接查表,返回
小李 2
小李 3
小李 4
mx 2
mx 4
这样的json,我不知道怎么得到
小李 [2,3,4]
mx [2,4]
这样的json
patosky
2014-03-24 11:31:52 +08:00
select name, GROUP_CONCAT(type) as type from table_name group by name
不知道这样行不行
@coolicer
coolicer
2014-03-24 11:46:15 +08:00
@patosky 可以。
plprapper
2014-03-24 13:14:39 +08:00
cancat group by

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/105580

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX