V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
yuanfnadi
V2EX  ›  程序员

写数据库语句遇到问题

  •  
  •   yuanfnadi · 2017-08-08 21:40:53 +08:00 via iPhone · 1803 次点击
    这是一个创建于 2452 天前的主题,其中的信息可能已经有所发展或是发生改变。
    表有两列
    a b
    1 2
    1 3
    2 3
    2 1
    2 2


    现在要求出所有的数字一共出出现了几列
    结果应该是
    1 3
    2 4
    3 3

    用数据库写我想到的方法是分别求出两列个数,相加以后减去相同的个数
    8 条回复    2017-08-13 13:05:27 +08:00
    yejinmo
        1
    yejinmo  
       2017-08-08 21:52:43 +08:00
    结果应该是
    1 3
    2 5
    3 3
    xxoxx
        2
    xxoxx  
       2017-08-08 21:54:16 +08:00
    目测了一下,结果应该是
    1 3
    2 5
    3 2
    yejinmo
        3
    yejinmo  
       2017-08-08 21:54:17 +08:00
    select a, count(a) from
    (
    (select a from test union all select b from test) as temp
    )
    group by a;
    yejinmo
        4
    yejinmo  
       2017-08-08 21:54:48 +08:00
    @yejinmo
    1 3
    2 5
    3 2
    yuanfnadi
        5
    yuanfnadi  
    OP
       2017-08-08 22:15:24 +08:00 via iPhone
    重复的不算
    应该是
    13
    24
    32

    33 是手抖了
    akira
        6
    akira  
       2017-08-08 22:45:08 +08:00
    SELECT a, SUM(`t`) `count`
    FROM
    (
    SELECT a, COUNT(a) `t`
    FROM test
    GROUP BY a UNION
    SELECT b, COUNT(b)
    FROM test
    WHERE a<>b
    GROUP BY b
    )tt
    GROUP BY a
    zeraba
        7
    zeraba  
       2017-08-08 23:04:31 +08:00 via Android
    就按照你的思路 把 a b 先并到一起 参考 3 楼 一样的随便取一个 最后 group by
    伪代码
    select case when a = b then a else a end hebing from test
    union
    select case when a <> b then b end hebing
    SuperMild
        8
    SuperMild  
       2017-08-13 13:05:27 +08:00
    select a, sum(num) as 'count' from
    (select a, count(a) as num from AandB where a <> b group by a
    union all
    select b, count(b) from AandB where a <> b group by b
    union all
    select b, count(b) from AandB where a = b group by b)
    group by a;
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3262 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 13:48 · PVG 21:48 · LAX 06:48 · JFK 09:48
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.