Сгруппируйте и получите отчетливое значение, которое встречается чаще всего - PullRequest
5 голосов
/ 08 декабря 2011

Я хочу сгруппировать по столбцу varchar и найти значение внешнего ключа, которое встречается чаще всего.Проблема заключается в том, что несколько моделей fiModel могут быть назначены одному и тому же TAC (первые 8 цифр 15-значного значения, называемого SSN_Number).

Вот упрощенная модель и запрос с данными выборки:

create table #data(
    SSN_Number varchar(15),
    fiModel int
)
insert into #data
        SELECT '351806038155151',451 UNION ALL SELECT '353797028764243',232 UNION ALL SELECT '353797028764243',438 UNION ALL SELECT '353797028764243',438 UNION ALL SELECT '353797028764243',447 UNION ALL SELECT '358372015611578',318 UNION ALL SELECT '352045039834626',279 UNION ALL SELECT '352045031234567',279 UNION ALL SELECT '351806035647381',451 UNION ALL SELECT '352045037654321',207

--- following query returns all records(10)
select * from #data Order By SSN_Number

--- following query gives the distinct TAC's+fiModel, but TACs can repeat (9)
select substring(ssn_number,1,8)as TAC,fiModel,count(*) from #data
group by substring(ssn_number,1,8),fiModel
Order By substring(ssn_number,1,8),fiModel

--- following query gives the correct(distinct) TAC's (4), 
--- but i need the fiModel that occurs most often with the assigned TAC
--- if the number is the same, it doesn't matter what to take
select substring(ssn_number,1,8)as TAC,count(*) from #data
group by substring(ssn_number,1,8)
Order By substring(ssn_number,1,8)

drop table #data

Итак, это желаемый результат:

TAC         fiModel
35180603    451
35204503    279
35379702    438
35837201    318

1 Ответ

2 голосов
/ 08 декабря 2011

Это должно сработать (CTE на помощь!):

;with cte as (
    select substring(ssn_number,1,8) as TAC, fiModel, ROW_NUMBER() OVER (PARTITION BY substring(ssn_number,1,8) ORDER BY count(*) desc) as row
    from #data
    group by substring(ssn_number,1,8),fiModel
)
select TAC, fiModel
from cte
where row = 1

Как подзапрос:

Select TAC,fiModel
from(
    Select substring(ssn_number,1,8)as TAC, fiModel
      ,ROW_NUMBER() OVER (PARTITION BY substring(ssn_number,1,8) ORDER BY count(*) desc) as row
    from #data
    group by substring(ssn_number,1,8),fiModel
)as data
where row=1
...