EntityFramework 6 分页模式

在我的另一篇博客中提到了EntityFrameworkCore 分页问题, 中提到了EntityFrameworkCore在针对不同版本SQL Server数据库时如何指定分页模式,那么如何在EntityFramework 6中指定分页模式呢?

场景重现

在一个项目VS2010开发的项目中,我引用了EntityFramework 6,但数据库使用的是SQL Server 2012.

使用T4模版生成的数据库上下文,使用EntityFramework 6.Take().Skip()方法生成分页使用的是SQL Server 2008rows_number()方式.

出现了翻页操作时,页数越靠后,查询速度越慢的情况,4W条多表关联视图数据,第一页查询只用0.5毫秒,直接最后一页查询用了30多秒...

解决办法

然后就想如何在EntityFramework 6中启用SQL Server 2012中的新分页方式offset & fetch呢?

后来发现可以通过编辑器打开.edmx文件(是xml内容),修改ProviderManifestToken="2008"ProviderManifestToken="2012",然后编译运行,查看现在EntityFramework 6分页语句生成的sql就可以看到使用的是offset & fetch了,同时上面的问题已解决了,每页查询速度基本稳定在秒内.

同理是不是可以通过修改该属性值来使用SQL Server 2005的分页模式?

不过在VS2010中出现如下错误信息,不影响功能,但看着烦,暂时不知道如何消除?

我猜是不是受VS2010T4模版影响,下次换个高版本的VS或模版看看?

  • 后来使用VS2017生成数据库实体,发现ProviderManifestToken默认就为2012
  • 重新使用VS2010生成数据库实体,发现ProviderManifestToken默认又是2008

参考文档

转载于:https://my.oschina.net/taadis/blog/1595828

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值