English 中文(简体)
Can I Nest OrderBy in .NET?
原标题:

This doesn t seem to work as I intend.

VB.NET:

Dim x = Model.Discussions.OrderByDescending(Function(d) d.Messages.OrderByDescending(Function(m) m.Sent).First.Sent)
For Each d As Discussion In x
    ...
Next

I get this runtime error:

Sequence contains no elements

There should be 20.

Discussions are collections of messages.

I want to sort my discussions by the age of the newest message of each.

Clarification

I need to sort my discussions, not my messages. I want to sort my discussions by an aggregate calculation: MAX(Sent) among the messages of each.

最佳回答

I don t think you need OrderBy in the inner query at all - use Max (or Min):

Model.Discussions.OrderByDescending( _
    Function(d) d.Messages.Max(Function(m) m.Sent))

Though in VB, I d rather use a query comprehension:

From d In Model.Discussions _
Order By (Aggregate m In d.Messages Into Max(m.Sent)) Descending _
Select d

The reason why you ve got the error that you did is, apparently, because you have some discussion with no messages; hence calling First thrown an exception. Max will do the same. I m not sure if this is a problem with your data set (it doesn t seem like it s reasonable to have a discussion with no messages in it), but if it is, you need to use Enumerable.Empty() for an extra check.

问题回答

You need to use .OrderByDescending().ThenBy();





相关问题
Manually implementing high performance algorithms in .NET

As a learning experience I recently tried implementing Quicksort with 3 way partitioning in C#. Apart from needing to add an extra range check on the left/right variables before the recursive call, ...

Anyone feel like passing it forward?

I m the only developer in my company, and am getting along well as an autodidact, but I know I m missing out on the education one gets from working with and having code reviewed by more senior devs. ...

How do I compare two decimals to 10 decimal places?

I m using decimal type (.net), and I want to see if two numbers are equal. But I only want to be accurate to 10 decimal places. For example take these three numbers. I want them all to be equal. 0....

Exception practices when creating a SynchronizationContext?

I m creating an STA version of the SynchronizationContext for use in Windows Workflow 4.0. I m wondering what to do about exceptions when Post-ing callbacks. The SynchronizationContext can be used ...

Show running instance in single instance application

I am building an application with C#. I managed to turn this into a single instance application by checking if the same process is already running. Process[] pname = Process.GetProcessesByName("...

How to combine DataTrigger and EventTrigger?

NOTE I have asked the related question (with an accepted answer): How to combine DataTrigger and Trigger? I think I need to combine an EventTrigger and a DataTrigger to achieve what I m after: when ...

热门标签