知道为什么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());
同样的结果,没有订购......
我确实有解决方法,但只是想知道缺少什么......
非常感谢任何建议: - )
答案 0 :(得分:33)
不要丢弃返回值。 OrderBy
扩展方法是不改变输入。尝试:
newView = newView.OrderBy(x => x.viewed);
假设viewed
值正确,没有理由不这样做。此外,请确保OrderBy
在任何操作之后(例如Distinct
),这将破坏排序。
快乐的编码!
答案 1 :(得分:0)
如果结果是只读结果,请考虑在 orderby() 之后使用 asnotracking()。
示例:
query = query.OrderByDescending(x => x.Rating).AsNoTracking();