加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 无法将IQueryable <>转换为IOrderedQueryable错误

发布时间:2020-12-15 03:47:19 所属栏目:百科 来源:网络整理
导读:我有以下LINQ代码: 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); } 最后一
我有以下LINQ代码:
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);
        }

最后一行(额外的地方)给我的错误:

不能将“System.Linq.IQueryable”类型隐式转换为“System.Linq.IOrderedQueryable”.

我不知道这是什么意思
为什么我得到这个错误?
一旦我在查询中添加了“orderby”子句,就可以在编译好之前出现,所以我有一种预感,但是我不能把我的手指放在这里.

解决方法

尝试将帖子专门声明为IQueryable< Post>而不是var(它会拾取IOrderedQueryable< Post>(它仍将被排序).

或者,重新构造它,所以我们在最后订购,允许我们(可选)带入中间的位置:

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);

(显然,我们看看finalQuery)

错误的原因是目前您(基本上):

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读