Search code examples
c#linq-to-sqltype-conversioniqueryableiorderedqueryable

Cannot convert IQueryable<> to IOrderedQueryable error


I have the following LINQ code:

    var posts = (from p in db.Posts
         .Include("Site")
         .Include("PostStatus")
        where p.Public == false
        orderby p.PublicationTime 
        select p);

        if (!chkShowIgnored.Checked) {
            posts = posts.Where(p => p.PostStatus.Id != 90);
        }

That last line (the extra where) is giving me the error:

Cannot implicitly convert type 'System.Linq.IQueryable' to 'System.Linq.IOrderedQueryable'.

I'm not sure what this means...
Why am I getting this error?
It appeared once I added the "orderby" clause to the query, before that it compiled fine, so I have kind of a hunch of what is going on, but I can't quite put my finger into it.


Solution

  • Try declaring posts specifically as IQueryable<Post> rather than var (which will pick up the IOrderedQueryable<Post> (it will still be ordered).

    Alternatively, re-structure it so we order at the end, allowing us to (optionally) bring in the where in the middle:

    var posts = from p in db.Posts
                 .Include("Site")
                 .Include("PostStatus")
                where p.Public == false
                select p);
    
    if (!chkShowIgnored.Checked) {
        posts = posts.Where(p => p.PostStatus.Id != 90);
    }
    var finalQuery = posts.OrderBy(p => p.PublicationTime);
    

    (obviously, we look at finalQuery)

    The reason it is erroring is that currently you have (essentially):

    IOrderedQueryable<Post> posts = {snip};
    ...
    posts = {something (Where) that returns IQueryable<Post>}