سؤال

وأنا جديدة تماما ل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