Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 160699
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T11:04:53+00:00 2026-05-11T11:04:53+00:00

According to Pro LINQ: Language Integrated Query in C# 2008 , Prototype of OrderBy

  • 0

According to Pro LINQ: Language Integrated Query in C# 2008, Prototype of OrderBy operator is

public static IOrderedEnumerable<T> OrderBy<T, K>(     this IEnumerable<T> source,     Func<T, K> keySelector) where     K : IComparable<K> 

But the MSDN documentation does not have a generics contraint on TKey that it should be of type IComparable<TKey>

public static IOrderedEnumerable<TSource> OrderBy<TSource, TKey>(     this IEnumerable<TSource> source,     Func<TSource, TKey> keySelector ) 

I am basically sorting Inventory by Unit and then by Size.

    var sortedInventories = inventories                             .OrderBy(inventory => inventory.Unit)                             .OrderBy(inventory => inventory.Size); 

From the above code snippet, lambda expressions simply return inventory properties to sort by. It does not look like an expression that returns IComparer<T>

But according to logic, it looks like the lambda expression should be of type IComparer<T>.

Which one is the correct declaration of OrderBy?
(Apress.com Errata page has no information on it)

Here is a sample application I created to test OrderBy

public class Program {     public static void Main(string[] args)     {         var inventories = new[] {             new Inventory { Unit = 1, Size = 2 },             new Inventory { Unit = 2, Size = 4 },             new Inventory { Unit = 3, Size = 6 },         };         var sortedInventories = inventories                                 .OrderBy(inventory => inventory.Unit)                                 .OrderBy(inventory => inventory.Size);          foreach (var inventory in sortedInventories)             Console.WriteLine('Unit: {0}; Size = {1}', inventory.Unit, inventory.Size);     } }  public class Inventory {     public int Unit { get; set; }     public double Size { get; set; } } 
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T11:04:53+00:00Added an answer on May 11, 2026 at 11:04 am

    Change your second ‘OrderBy’ to ‘ThenBy’. You’re currently resorting everything, so it’s effectively by Size and then Unit, but inefficiently. I’m not sure where you think IComparer<T> should come in, unless you specify it as another argument. Basically it uses Comparer<T>.Default unless you specify a separate comparer.

    Anyway, your query should be:

    var sortedInventories = inventories                           .OrderBy(inventory => inventory.Unit)                           .ThenBy(inventory => inventory.Size); 

    (With your test data you can’t tell the difference, because in each case Size = Unit * 2. Try it with one item which has a small Unit and a large Size though.)

    Yes, it looks like the book got the signature slightly wrong – possibly due to it changing shortly before release. If you were basically worried about getting the wrong results though, the above is the explanation.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

According to this discussion , the iphone agreement says that it doesn't allow loading
According to the answers to this question, I cannot embed a file version in
According to this article Silverlight 2 Beta 2 supports the DataContractJsonSerializer object. But, when
I've tried dotfuscator.exe /in:myassembly.dll, According to the command line documentation , this should dotfuscate
According to the manual , git dcommit will create a revision in SVN for
According to the documentation, they're pretty much interchangeable. Is there a stylistic reason to
According to MSDN form.RightToLeftLayout = True; form.RightToLeft = ifWeWantRTL() ? RightToLeft.True : RightToLeft.False; is
According to select name from system_privilege_map System has been granted: SELECT ANY TABLE ...and
According to what I have found so far, I can use the following code:
According to Wikipedia, on the Comparison of programming languages page, it says that F#

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.