首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >按组计数列出SQL数据

按组计数列出SQL数据
EN

Stack Overflow用户
提问于 2013-07-24 10:14:46
回答 1查看 106关注 0票数 0

我希望您能帮助我处理一个我似乎搞不懂的SQL语句。

我有一张桌子,上面有访问的名单,访问的国家和日期,例如;

  • 联合王国,2009年11月1日
  • 德国,2010年6月8日
  • Frane,2011年9月10日
  • 联合王国,2011年10月11日

等。

我希望提取数据,以便得到如下所示的表列表

访问时间-国家名单

  • 23 -联合王国
  • 10 -法国、德国
  • 4-捷克共和国、美国、加拿大
  • 1-波兰、塞尔维亚、阿根廷、新西兰

所以数据显示我去了捷克,美国和坎达

和查询

代码语言:javascript
运行
复制
select * from 
(
    select count(*) as "trips", country from trip_view
    group by country
    order by 1 desc
) as a

返回数据

  • 23联合王国
  • 10法国
  • 10德国
  • 4捷克共和国
  • 4美国
  • 4加拿大
  • 等。

因此,我需要在外部SQL上设置一个组,但是如果我执行以下操作

代码语言:javascript
运行
复制
select * from 
(
    select count(*) as "trips", country from trip_view
    group by country
    order by 1 desc
) as a
group by trips

然后我只得到一个国家的参赛资格。即

  • 23联合王国
  • 10法国
  • 4捷克共和国
  • 等。

因此,对于每一行,我只列出一个国家,而不是所有国家。第二排应显示法国和德国,第三排应显示捷克、美国和加拿大

有什么想法吗?如何在mysql中做到这一点?

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-07-24 10:34:04

在country列上使用GROUP_CONCAT应该会产生您想要的结果:

代码语言:javascript
运行
复制
  SELECT trips, 
         GROUP_CONCAT(country) AS country 
    FROM (
           SELECT COUNT(*) AS "trips", 
                  country 
             FROM trip_view
         GROUP BY country
         ) a
GROUP BY trips
ORDER BY 1 DESC

输出:

代码语言:javascript
运行
复制
TRIPS   COUNTRY
   23   United Kingdom
   10   France,Germany
    4   Czech Republic,Canada,USA

Live DEMO.

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17831073

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档