EntityFramework & RowNumber - PullRequest
       5

EntityFramework & RowNumber

0 голосов
/ 07 апреля 2010

Как я могу запросить RowNumber с Entity Framework? Например:

        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.

Может быть, есть другой способ реализовать это?

1 Ответ

1 голос
/ 08 апреля 2010

Вы можете использовать пропуск, взятие или ряд других методов подкачки, поддерживаемых для LINQ to Entities:

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

... даст вам первые десять строк.Не уверен, насколько это эффективно, но эти ссылки могут помочь найти лучшее решение вашей индивидуальной проблемы.

...