LINQ - написание запроса с четким и упорядоченным

StackOverflow https://stackoverflow.com/questions/1235604

  •  22-07-2019
  •  | 
  •  

Вопрос

Я довольно новичок в LINQ.

Предположим, у меня была следующая таблица:

Incident 

ID DeviceID Time          Info

1    1      5/2/2009    d

2    2      5/3/2009    c

3    2      5/4/2009    b

4    1      5/5/2009    a

Как в LINQ написать запрос, который находит самый последний и различимый (по идентификатору устройства) набор инцидентов? Я бы хотел получить такой результат:

ID DeviceID Time           Info

3    2      5/4/2009    b

4    1      5/5/2009    a

Вам нужно создать IEqualityComparer для этого?

Это было полезно?

Решение

Вы можете получить самые последние сообщения об инцидентах для каждого устройства (вот как я понял ваш вопрос) с помощью:

var query = 
   incidents.GroupBy(incident => incident.DeviceID)
            .Select(g => g.OrderByDescending(incident => incident.Time).First())
            .OrderBy(i => i.Time); // only add if you need results sorted

Другие советы

int filterDeviceID = 10;

var incidents = (from incident in incidentlist
                where incident.DeviceID == filterDeviceID
                select incident).Distinct().OrderBy( x => x.Time);
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top