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服务器中没有分页,我认为这样的分页没有任何优势。我是否错过了一些无法正常工作的东西?或者它是这样工作的?
PagedList
将 Skip()
和 Take()
附加到您的查询(计算要从 PageNumber
和 PageSize
跳过的行数)。但查询应该是原始的 IQueryable
,因为这些添加内容会到达查询提供者并影响 SQL 翻译。 ToList
中断此连接。
在我的项目中,我需要对查询进行分页。我使用 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服务器中没有分页,我认为这样的分页没有任何优势。我是否错过了一些无法正常工作的东西?或者它是这样工作的?
PagedList
将 Skip()
和 Take()
附加到您的查询(计算要从 PageNumber
和 PageSize
跳过的行数)。但查询应该是原始的 IQueryable
,因为这些添加内容会到达查询提供者并影响 SQL 翻译。 ToList
中断此连接。