当前位置: 代码迷 >> 综合 >> .net core3.1 下“‘OFFSET‘ 附近有语法错误。在 FETCH 语句中选项 NEXT 的用法无效。“
  详细解决方案

.net core3.1 下“‘OFFSET‘ 附近有语法错误。在 FETCH 语句中选项 NEXT 的用法无效。“

热度:45   发布时间:2024-01-11 21:41:53.0

在.net core下EntityFrameworkCore操作数据库有些变化

由于新版的EntityFrameworkCore默认使用的是SqlServer2012或以上版本的Sql语法分页,来提高性能。
 //所以使用数据库的版本如果低于2012(如Sqlserver2008)需要显示的指定代码:b => b.UseRowNumberForPaging()
 services.AddDbContextPool<oaEntities>(b => b.UseSqlServer(Configuration.GetConnectionString("SqlServer"), c => c.UseRowNumberForPaging()));

在.net core3.0前是可以这么使用的

但是在.net core3.0之后这么使用就会报错"'OFFSET' 附近有语法错误。在 FETCH 语句中选项 NEXT 的用法无效。"

后来网上查了下EntityFrameworkCore3.0开始支持sql2012了,好像对之前的数据库放弃支持了。

EF Core 3.0 从 Preview 6 开始不支持UseRowNumberForPaging,

就把EF的版本降到了Preview 5试了下就行了。

  相关解决方案