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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值