0

如何使用实体框架查询 RowNumber?例如:

        var result = data.Users
            .OrderByDescending("Birthday")
            .ThenBy("LastName")
            .ThenBy("FirstName")
            .Select(u =>
                        {
                            RowNumber = ???,
                            u.FirstName,
                            u.LastName
                        });

我想为我的网格实现分页,但我无法解决查找需要用户的页面的问题。

我正在使用 EF4.0。带索引的选择方法(http://msdn.microsoft.com/en-us/vcsharp/aa336758.aspx#SelectIndexed)不适用于 EF。

可能有另一种方法来实现这一点吗?

4

1 回答 1

1

您可以使用 LINQ to Entities 支持的 skip、take 或许多其他分页方法:

http://msdn.microsoft.com/en-us/library/bb738474.aspx

http://msdn.microsoft.com/en-us/library/bb738702.aspx

例如:

var result = data.Users 
            .OrderByDescending("Birthday") 
            .ThenBy("LastName") 
            .ThenBy("FirstName") 
            .Select(u => 
                        { 
                            u.FirstName, 
                            u.LastName 
                        }).Take(10); 

...会给你前十行。不确定这有多有效,但这些链接可能有助于找到针对您个人问题的最佳解决方案。

于 2010-04-07T20:11:48.143 回答