最近.Net EF core 程序部署到服务器,服务器数据库安装的是SQL server 2008 R2,我本地用的的是SQL server 2014,在用到分页查询时报错如下:
How to avoid the “Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement.”
通过问题描述可以分析是数据库SQL server 2008 R2版本SQL语句不支持关键字OFFSET,NEXT,因为这两个关键字是SQL server 2012以后的新特性。
由于我采用的是.Net core EF code first访问数据库,在网上查找如何制定数据库版本,没有太多有用的资料。最后在EntityFrameworkCore官方开源github issue里找到了解决方案,因为已经有人先遇到这个问题了。
Github issue连接地址:https://github.com/aspnet/EntityFrameworkCore/issues/4616
通过配置.UseRowNumberForPaging() 即配置用row number SQL关键字进行分页,详细代码如下:
public static class MyDBContextConfigurer { public static void Configure(DbContextOptionsBuilder<MyDBContext> builder, string connectionString) { builder.UseSqlServer(connectionString, option => option.UseRowNumberForPaging() ); } public static void Configure(DbContextOptionsBuilder<MyDBContext> builder, DbConnection connection) { builder.UseSqlServer(connection, option => option.UseRowNumberForPaging()); }}