在个人另外一篇博客中提到了EntityFrameworkCore 分页问题, 中提到了EntityFrameworkCore
在针对不一样版本SQL Server数据库时如何指定分页模式,那么如何在EntityFramework 6
中指定分页模式呢?html
在一个项目VS2010
开发的项目中,我引用了EntityFramework 6
,但数据库使用的是SQL Server 2012
.sql
使用T4
模版生成的数据库上下文,使用EntityFramework 6
的.Take().Skip()
方法生成分页使用的是SQL Server 2008
的rows_number()
方式.数据库
出现了翻页操做时,页数越靠后,查询速度越慢的状况,4W条多表关联视图数据,第一页查询只用0.5毫秒,直接最后一页查询用了30多秒...编辑器
而后就想如何在EntityFramework 6
中启用SQL Server 2012
中的新分页方式offset & fetch
呢?ide
后来发现能够经过编辑器打开.edmx
文件(是xml内容),修改ProviderManifestToken="2008"
为ProviderManifestToken="2012"
,而后编译运行,查看如今EntityFramework 6
分页语句生成的sql
就能够看到使用的是offset & fetch
了,同时上面的问题已解决了,每页查询速度基本稳定在秒内.fetch
同理是否是能够经过修改该属性值来使用SQL Server 2005
的分页模式?.net
不过在VS2010
中出现以下错误信息,不影响功能,但看着烦,暂时不知道如何消除?code
我猜是否是受VS2010
或T4
模版影响,下次换个高版本的VS或模版看看?xml
VS2017
生成数据库实体,发现ProviderManifestToken
默认就为2012
VS2010
生成数据库实体,发现ProviderManifestToken
默认又是2008
参考文档htm