LINQ2SQL中的EntitySet与Table查询性能

tha*_*att 9 linq ienumerable iqueryable linq-to-sql

在LINQ to SQL类,为什么属性是从外键创建EntitySet对象,实施IEnumerable,作为地方上的对象DataContextTable其实现目标IQueryable

编辑:澄清一下,这是一个例子,说明了我想要了解的内容.这个例子:

ctx.Matches.Where(x => x.MatchID == 1).Single()
           .MatchPlayers.Max(x => x.Score);
Run Code Online (Sandbox Code Playgroud)

在以下位置点击数据库两次:

ctx.MatchPlayers.Where(x => x.MatchID == 1)
                .Max(x => x.Score);
Run Code Online (Sandbox Code Playgroud)

只运行1个查询.以下是痕迹:

exec sp_executesql N'SELECT [t0].[MatchID], [t0].[Date]
FROM [dbo].[Matches] AS [t0]
WHERE [t0].[MatchID] = @p0',N'@p0 int',@p0=1
go
exec sp_executesql N'SELECT [t0].[MatchID], [t0].[PlayerID], [t0].[Score]
FROM [dbo].[MatchPlayers] AS [t0]
WHERE [t0].[MatchID] = @p0',N'@p0 int',@p0=1
go
Run Code Online (Sandbox Code Playgroud)

exec sp_executesql N'SELECT MAX([t0].[Score]) AS [value]
FROM [dbo].[MatchPlayers] AS [t0]
WHERE [t0].[MatchID] = @p0',N'@p0 int',@p0=1
go
Run Code Online (Sandbox Code Playgroud)

这也表明,更糟糕的是,max是在C#级别而不是在数据库中完成的.

我知道发生这种情况的原因是IQueryables和IEnumerables 之间的区别,所以为什么MatchPlayers第一个示例中的对象不实现IQueryable接口以获得与后一个示例相同的好处.

Jon*_*eet 1

表实际上是一个概念问题 - 它们确实存在于服务器上,因此您需要查询才能获取条目。外键条目是另一个查询实际获取的条目,因此此时它们在本地可用。这是一个相当模糊的描述,但希望它能涵盖一般概念。