在.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试了下就行了。