【.net core 入坑】.net core 3.0 报错:在 FETCH 语句中选项 NEXT 的用法无效


1、事故现场:

在项目中使用.net core 3.0,在EF链接sqlserver2008,在程序中使用了分页用的skip和take,程序报错:

在 FETCH 语句中选项 NEXT 的用法无效。

2、分析及解决方案:

因为分页skip和take转成sql的时候默认是使用FETCHNEXT的,而不是可兼容低版本sqlserver的ROWNUMBER(),所以报错;
在之前的.net core 版本中,可以通过重写OnConfiguring,配置UseRowNumberForPaging即可,代码如下:

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            if (!optionsBuilder.IsConfigured)
            {
                optionsBuilder.UseSqlServer(Config.Instance.GetConnctionString("SqlServer"), options =>
                {
                    options.UseRowNumberForPaging();
                });
            }
        }

但是,在.net core 3.0中改写法已经不起作用;
经过一番查询,发现UseRowNumberForPaging has been removed in 3.0
参考链接:添加链接描述
在这里插入图片描述
解决方案:只能升级sqlserver到2012及以上;


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值