PagedList 不会在 asp.net mvc 中进行真正的分页

PagedList doesn't make a real paging in asp.net mvc

在我的项目中,我需要对查询进行分页。我使用 entity framework 从数据库中获取数据。 This video on youtube 解释如何对查询进行分页。简而言之,视频说您所要做的就是将 PagedList.Mvc 安装到您的项目中,此代码

.ToPagedList(PageNumber,PageSize)

第一次,这似乎对我有用,但我发现(在使用 Sql 服务器配置文件检查 entity framework 传递给 sql server) entity framework 向 sql 服务器询问所有数据,然后 select 需要的数据。更清楚地说,这是我在 C# 上的代码(服务器端)

var messages = db.Messages.Where(x => x.User1 == 1 && x.User2 == 2).OrderBy(x=>x.Date).ToList().ToPagedList(1,4);

传递给 sql 服务器的是:

exec sp_executesql N'SELECT 
    [Project1].[Id] AS [Id], 
    [Project1].[User1] AS [User1], 
    [Project1].[User2] AS [User2], 
    [Project1].[Direction] AS [Direction], 
    [Project1].[TextContent] AS [TextContent], 
    [Project1].[ReadBit] AS [ReadBit], 
    [Project1].[Date] AS [Date], 
    [Project1].[ReceivedBit] AS [ReceivedBit]
    FROM ( SELECT 
        [Extent1].[Id] AS [Id], 
        [Extent1].[User1] AS [User1], 
        [Extent1].[User2] AS [User2], 
        [Extent1].[Direction] AS [Direction], 
        [Extent1].[TextContent] AS [TextContent], 
        [Extent1].[ReadBit] AS [ReadBit], 
        [Extent1].[ReceivedBit] AS [ReceivedBit], 
        [Extent1].[Date] AS [Date]
        FROM [Messages].[Messages] AS [Extent1]
        WHERE ([Extent1].[User1] = @p__linq__0) AND ([Extent1].[User2] = @p__linq__1)
    )  AS [Project1]
    ORDER BY [Project1].[Date] ASC',N'@p__linq__0 int,@p__linq__1 int',@p__linq__0=1,@p__linq__1=2

所以在sql服务器中没有分页,我认为这样的分页没有任何优势。我是否错过了一些无法正常工作的东西?或者它是这样工作的?

PagedListSkip()Take() 附加到您的查询(计算要从 PageNumberPageSize 跳过的行数)。但查询应该是原始的 IQueryable,因为这些添加内容会到达查询提供者并影响 SQL 翻译。 ToList 中断此连接。