Oracle group / count count - PullRequest
       14

Oracle group / count count

3 голосов
/ 13 декабря 2011

У меня есть следующие две таблицы:

TableOne
========
Id1|ColA1|ColB1|ColC1|ColD1|ColE1
--------------------------------
  1| AFoo|BFoo |CFoo | DFoo| EFoo
  2| AFoo|BBar |CFoo | DFoo| EFoo

TableTwo
========
Id2|ColA2|ColB2|ColC2
---------------------
 11| 1   |ABC  |NOP  |
 12| 1   |ABC  |QRS  |
 13| 1   |DEF  |TUV  |
 14| 1   |DEF  |WXY  | 
 15| 1   |DEF  |FGH  | 
 16| 2   |ABC  |NOP  | 

Я запускаю следующий запрос:

select t1.*, t2.*
from TableOne t1
inner join TableTwo t2 on t2.ColA2=t1.Id1
where t1.ColA1='AFoo'

и получите следующий результат:

Result
======
Id1|ColA1|ColB1|ColC1|ColD1|ColE1|Id2|ColA2|ColB2|ColC2
-------------------------------------------------------
  1| AFoo|BFoo |CFoo | DFoo| EFoo| 11| 1   | ABC | NOP
  1| AFoo|BFoo |CFoo | DFoo| EFoo| 12| 1   | ABC | QRS
  1| AFoo|BFoo |CFoo | DFoo| EFoo| 13| 1   | DEF | TUV
  1| AFoo|BFoo |CFoo | DFoo| EFoo| 14| 1   | DEF | WXY
  1| AFoo|BFoo |CFoo | DFoo| EFoo| 15| 1   | DEF | FGH
  2| AFoo|BBar |CFoo | DFoo| EFoo| 16| 2   | ABC | NOP

Я действительно хочу вернуть:

Desired Result
======
Id1|MaxDup
----------------------------------------
  1| 3 (This is because there are 3 DEF records)
  2| 1 (This is because there is 1 ABC record)

Итак, я пытаюсь отследить максимальное количество вхождений в ColB2, которое появляется для каждой строки TableOne. В приведенном выше примере ID1 из 1 имеет две записи ABC и три записи DEF, связанные с ним. Поскольку записей DEF больше, чем записей ABC, я хочу вернуть количество записей DEF.

Кто-нибудь может привести рабочий пример, который может это продемонстрировать?

Ответы [ 4 ]

1 голос
/ 13 декабря 2011

Попробуйте это (я не проверял):

with t2 as (
    select  ColA2, ColB2, count(*) cnt 
    from TableTwo
    group by ColA2, ColB2 
)
select t1.Id1,
(  select max(cnt) MaxDup
   from t2
   where t2.ColA2=t1.Id1)
from TableOne t1
0 голосов
/ 13 декабря 2011

Может быть, этот?

SELECT t2.id2 id, count(t2.ColB2) MaxDup
FROM TableTwo t2
WHERE EXISTS(
      SELECT * FROM TableOne t1
      WHERE t1.id1 = t2.id2
      AND t1.ColA1='AFoo')
AND rownum < 2
GROUP BY t2.id2, t2.ColB2
ORDER BY MaxDup desc;
0 голосов
/ 13 декабря 2011

Вот результат, основанный на ваших тестовых данных.

SQL> select       
        cola2
        , cnt as maxDup
from (        
        select       
                cola2
                , colb2
                , cnt
                , rank() over (partition by cola2 order by cnt desc ) cnt_rnk
        from (
                select cola2
                       , colb2
                       , count(*) as cnt
                from  TableTwo
                group by cola2, colb2
        )
    )        
where     cnt_rnk = 1
/
  2    3    4    5    6    7    8    9   10   11   12   13   14   15   16   17   18   19  
COLA     MAXDUP
---- ----------
1             3
2             1

SQL>

Самый внутренний запрос подсчитывает дубликат.Средний запрос ранжирует количество дубликатов.Самые внешние фильтры запросов для комбо с наибольшим количеством:

0 голосов
/ 13 декабря 2011

Это код SQL Server, но я думаю, что его можно безопасно перенести в Oracle:

    select  id1,cola1,colb1,colc1,cold1,cole1,max(dup) as dup2  from (
        select t1.id1, t1.cola1, t1.colb1, t1.colc1,t1.cold1,t1.cole1, t2.colb2,count(*) as dup
        from t1 
        inner join  t2  on t2.cola2=t1.Id1
        where t1.cola1='Afoo'
        group by t1.id1, t1.cola1, t1.colb1, t1.colc1,t1.cold1,t1.cole1, t2.colb2) 
    tab
    group by id1,cola1,colb1,colc1,cold1,cole1

Он работает на Sql Server, и, заключив в подзапрос, вы можете извлечь только id1 и dup2. Попытка расширения набора данных, это работает.

...