jc-dsa 2019-07-12 19:25 采纳率: 62.5%
浏览 630
已采纳

SQL server2008r2 怎么统计一个表内单列对应的省城市数量

表1

aa bb 省 城市

11 张 浙江 杭州

22 王 河南 郑州

33 李 河南 洛阳

44 赵 陕西 汉中

22 王 河南 郑州

55 张 浙江 杭州

66 王 上海 上海

44 刘 福建 厦门

select bb,count(aa) as pageCount from 表1 group by bb 


order by

       pageCount DESC

我现在用得只能统计bb下面得张,王,李得数量,后面对应得省城市数量没有,怎么才能统计成下面这样:

表2

bb 省 城市 数量

张 浙江 杭州 2

王 河南 郑州 2

李 河南 洛阳 1

赵 陕西 汉中 1

王 上海 上海 1

刘 福建 厦门 1

  • 写回答

3条回答 默认 最新

  • threenewbee 2019-07-12 20:55
    关注

    group by bb之后按理说结果不应该出现两个王了啊。
    要你输出的那样应该是
    select bb,省,市,count(aa) as 数量 from 表1 group by bb,省,市
    order by 数量 DESC

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • liupan6889 2019-07-13 08:39
    关注

    Group by 省,group by 市

    评论
  • 大浪淘鲨 2019-07-13 09:36
    关注

    CREATE TABLE #tab
    (
    aa INT,
    bb NVARCHAR(20),
    province NVARCHAR(20),
    city NVARCHAR(50)
    )
    INSERT INTO #tab
    ( aa, bb, province, city )
    VALUES ( 11,'张' ,'浙江',' 杭州'),
    ( 22 ,'王','河南', '郑州'),
    ( 33 ,'李' ,'河南', '洛阳'),
    ( 44 ,'赵', '陕西' ,'汉中'),
    ( 22 ,'王', '河南', '郑州'),
    ( 55 ,'张', '浙江', '杭州'),
    ( 66, '王', '上海', '上海'),
    (44, '赵', '福建', '厦门')

    SELECT a.*,b.city FROM (
    SELECT aa,bb,province FROM #tab GROUP BY aa,bb,province) a INNER JOIN
    (SELECT aa,bb,city FROM #tab GROUP BY aa,bb,city) b ON a.aa=b.aa GROUP BY a.aa,a.bb

    SELECT a.aa,a.bb,a.c cs,b.c bs FROM (
    SELECT aa,bb,COUNT(a.province) c FROM (
    SELECT aa,bb,province FROM #tab GROUP BY aa,bb,province) a GROUP BY aa,bb
    )a
    INNER JOIN (
    SELECT aa,bb,COUNT(a.city) c FROM (
    SELECT aa,bb,city FROM #tab GROUP BY aa,bb,city) a GROUP BY aa,bb
    ) b ON a.aa=b.aa
    直接运行出结果!!!

    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 我不明白为什么c#微软的官方api浏览器为什么不支持函数说明的检索,有支持检索函数说明的工具吗?
  • ¥15 ORBSLAM2框架跑ICL-NUIM数据集
  • ¥15 在我想检测ros是否成功安装时输入roscore出现以下
  • ¥30 老板让我做一个公司的投屏,实时显示日期,时间,安全生产的持续天数,完全没头绪啊
  • ¥15 Google Chrome 所有页面崩溃,三种解决方案都没有解决,我崩溃了
  • ¥20 使用uni-app发起网络请求,获取重定向302返回的cookie
  • ¥20 手机外部浏览器拉起微信小程序支付 (相关搜索:微信小程序)
  • ¥20 怎样通过一个网址找到其他同样模版的网址
  • ¥30 XIAO esp32c3 读取FDC2214的数据
  • ¥15 在工控机(Ubuntu系统)上外接USB蓝牙硬件进行蓝牙通信