LINQ OrderBy不订购..一无所获..为什么?

时间:2012-05-24 19:19:40

标签: linq entity-framework sql-order-by iqueryable

知道为什么LINQ OrderBy不能在下面的代码中工作,(没有错误,但方法没有排序......)

首先是我自己的类型

public class IQLinksView
    {
        public int id { get; set; }
        public int catid { get; set; }
        public int? viewed {get;set;}
        public string name {get;set;}
        public string desc {get;set;}
        public string url {get;set;}
        public string pic {get;set;}
        public string cat {get;set;}
    }

然后查询:

IQueryable<IQLinksView> newView = 
              from links in this.emContext.tbl_otherlinks
              select new IQLinksView { id = links.pklinkid, catid =
              links.tbl_catgeory.pkcategoryid, viewed = links.linkviewed, name = links.linkname, 
              desc = links.linkdesc, pic = links.linkpicture,   url = links.linkurl, cat =
              links.tbl_catgeory.categoryname };

直到这里一切都很好:-),但随后

newView.OrderBy(x => x.viewed);

只是改变什么,...页面正在加载结果显示...但没有订购......嗅探

我试过(创建一个比较对象......):

newView.OrderBy(x => (Int32)x.viewed, new CompareIntegers());

同样的结果,没有订购......

我确实有解决方法,但只是想知道缺少什么......

非常感谢任何建议: - )

2 个答案:

答案 0 :(得分:33)

不要丢弃返回值。 OrderBy扩展方法是改变输入。尝试:

newView = newView.OrderBy(x => x.viewed);

假设viewed值正确,没有理由不这样做。此外,请确保OrderBy在任何操作之后(例如Distinct),这将破坏排序。

快乐的编码!

答案 1 :(得分:0)

No-Tracking Queries

如果结果是只读结果,请考虑在 orderby() 之后使用 asnotracking()。

示例:

query = query.OrderByDescending(x => x.Rating).AsNoTracking();