【.net core 入坑】.net core 3.0 报错:在 FETCH 语句中选项 NEXT 的用法无效
1、事故现场:
在项目中使用.net core 3.0,在EF链接sqlserver2008,在程序中使用了分页用的skip和take,程序报错:
在 FETCH 语句中选项 NEXT 的用法无效。
2、分析及解决方案:
因为分页skip和take转成sql的时候默认是使用FETCH
和NEXT
的,而不是可兼容低版本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及以上;
作者:willingtolove
出处:http://www.cnblogs.com/willingtolove/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步