При пагинации EF выдаёт ошибку Incorrect syntax near 'OFFSET'

131
12 декабря 2020, 18:40

Я использую следующий код для пагинации в EF Core:

 int page = 1, rowPerPage = 5;
 int count = ctx.Specialty.Count();
 int start = page * rowPerPage;
 var Select = ctx.Specialty.OrderByDescending(u => u.IdS)
            .Skip(start)
            .Take(rowPerPage)
            .AsEnumerable();

Использую SQL Server 2008 и Visual Studio 2017, проект ASP.NET Core.

Получаю следующиую ошибку:

Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement

Как исправить данную проблему?

Свободный перевод вопроса Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement "in Entity Framework core" от участника @Alireza.

Answer 1

Существует параметр совместимости (UseRowNumberForPaging) для подобного случая, может быть сконфигурировать либо в DbContext:

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
    var coonectionString = "Data Source=localhost\\MSSQLSERVER01;Initial Catalog=AppDb01;Integrated Security=True";
    optionsBuilder.UseSqlServer(coonectionString, builder => builder.UseRowNumberForPaging());
}

Либо в Startup.cs:

public void ConfigureServices(IServiceCollection services)
{
    var coonectionString = "Data Source=localhost\\MSSQLSERVER01;Initial Catalog=AppDb01;Integrated Security=True";
    services.AddDbContext<AppDbContext>(options => options.UseSqlServer(coonectionString, builder => builder.UseRowNumberForPaging()));
}

Свободный перевод ответа https://stackoverflow.com/a/54200998/5752652 от участника @Elliott.

READ ALSO
Получения списка wifi android. _wifi.ScanResults пуст

Получения списка wifi android. _wifi.ScanResults пуст

Мне необходимо получить список доступных wifi сетейНа теперешний момент есть такой код

131
SQL UPDATE запрос c#

SQL UPDATE запрос c#

Хочу сделать запрос на обновление данныхВот мой код

133
Создание объекта внутри Job в Quartz.net

Создание объекта внутри Job в Quartz.net

Подскажите, как правильно работать с контекстом базы данных (ef core) внутри Job-ы Quartznet

109
Работа с полями экземпляра C#

Работа с полями экземпляра C#

Есть класс Options с несколькими листиками и другой класс Form1Создан экземпляр класса Options в классе Form1

92