使用group by查询并在postgresql中计数

问题描述 投票:0回答:1

我的查询:

select id_posizione as posizione, IDENTIFICATIVO_TRANSAZIONE as transazione, Count(IDENTIFICATIVO_TRANSAZIONE) as count_transazioni
from  GP_TRANSAZIONI
group by id_posizione, IDENTIFICATIVO_TRANSAZIONE order by id_posizione;

返回此结果:

POSIZIONE       TRANSAZIONE                             COUNT_TRANSAZIONI
264             35afec5d-a71e-56f6-94d9-vf111b7f7f27    3
265             51afec5d-c71e-46f6-94d9-fb221b7f7e65    1
265             69b04d6d-ef58-417c-b070-2d2c2da778ff    2
266             51afec5d-c71e-46f6-94d9-fb221b7f7e66    3
267             98c6fa08-7c85-49e6-9c1e-52bdd80c6bb2    7
268             146f9355-13f1-4fb2-a2e6-b55588e312fd    4
269             3a85ff57-54bf-4b0d-b2fd-3f69aa239467    3
270             03899fe7-607b-457f-bcfb-570c1511b33a    4
271             47ffb07b-b410-4591-ad89-f8b820ba0a85    2

我想用不同的“TRANSAZIONE”只提取“POSIZIONE”。在上面的返回数据中,只有“POSIZIONE”265有两个“TRANSAZIONE”。我想只提取265“POSIZIONE”。

postgresql-9.3
1个回答
0
投票

我不确定你问题的含义。你需要简单地添加一个having来过滤聚合列:

select id_posizione as posizione, IDENTIFICATIVO_TRANSAZIONE as transazione, Count(IDENTIFICATIVO_TRANSAZIONE) as count_transazioni
from  GP_TRANSAZIONI
group by id_posizione, IDENTIFICATIVO_TRANSAZIONE 
having Count(IDENTIFICATIVO_TRANSAZIONE)>1
order by id_posizione;

将返回

264     35afec5d-a71e-56f6-94d9-vf111b7f7f27    3
265     69b04d6d-ef58-417c-b070-2d2c2da778ff    2
266     51afec5d-c71e-46f6-94d9-fb221b7f7e66    3
267     98c6fa08-7c85-49e6-9c1e-52bdd80c6bb2    7
268     146f9355-13f1-4fb2-a2e6-b55588e312fd    4
269     3a85ff57-54bf-4b0d-b2fd-3f69aa239467    3
270     03899fe7-607b-457f-bcfb-570c1511b33a    4
271     47ffb07b-b410-4591-ad89-f8b820ba0a85    2

或者您需要通过添加count(distinct xxx)having关键字来重构您的查询:

select id_posizione as posizione, Count(distinct IDENTIFICATIVO_TRANSAZIONE) as count_transazioni
from  GP_TRANSAZIONI
group by id_posizione 
having Count(distinct IDENTIFICATIVO_TRANSAZIONE)>1
order by id_posizione;

哪个回归

265 2

© www.soinside.com 2019 - 2024. All rights reserved.