Я пытаюсь понять, почему соединение в моем случае происходит быстрее, чем оператор, который использует свойство навигации. У меня два запроса.Entity framework performance join vs navigation property
Сначала с свойства навигации:
var result = (from users in context.MetricBloodPreasure
orderby users.User.LastName, users.User.FirstName
select new
{
UserName = users.User.LastName + ", " + users.User.FirstName,
Date = users.DateOfValue,
}).ToList();
Generatet SQL:
SELECT
[Project1].[C1] AS [C1],
[Project1].[C2] AS [C2],
[Project1].[DateOfValue] AS [DateOfValue]
FROM (SELECT
[Extent1].[DateOfValue] AS [DateOfValue],
[Extent2].[FirstName] AS [FirstName],
[Extent2].[LastName] AS [LastName],
1 AS [C1],
CASE WHEN ([Extent2].[LastName] IS NULL) THEN N'' ELSE [Extent2].[LastName] END + N', ' + CASE WHEN ([Extent2].[FirstName] IS NULL) THEN N'' ELSE [Extent2].[FirstName] END AS [C2]
FROM [dbo].[MetricBloodPreasure] AS [Extent1]
INNER JOIN [dbo].[User] AS [Extent2] ON [Extent1].[UserId] = [Extent2].[Id]
) AS [Project1]
ORDER BY [Project1].[LastName] ASC, [Project1].[FirstName] ASC
Второй с присоединиться:
var result1 = (from u in context.User
orderby u.LastName, u.FirstName
join us in context.MetricBloodPreasure
on u.Id equals us.UserId into users
from s in users
select new
{
UserName = s.User.LastName + ", " + s.User.FirstName,
Date = s.DateOfValue,
}).ToList();
генерируемый SQL:
SELECT
1 AS [C1],
CASE WHEN ([Extent1].[LastName] IS NULL) THEN N'' ELSE [Extent1].[LastName] END + N', ' + CASE WHEN ([Extent1].[FirstName] IS NULL) THEN N'' ELSE [Extent1].[FirstName] END AS [C2],
[Extent2].[DateOfValue] AS [DateOfValue]
FROM [dbo].[User] AS [Extent1]
INNER JOIN [dbo].[MetricBloodPreasure] AS [Extent2] ON ([Extent1].[Id] = [Extent2].[UserId]) AND ([Extent2].[UserId] = [Extent1].[Id])
Перед запуском первого запроса позвоните var user = context.User.FirstOrDefault();
, потому что я думаю, что открытое соединение с базой данных занимает некоторое время.
Результаты: Навигация свойство запроса: 00: 00: 00,6719646 Регистрация запроса: 00: 00: 00,4941169
Глядя на результаты, кажется, что Linq запросов, что использование присоединяется вместо навигационных свойств быстрее. Это правда, или я делаю что-то неправильно?
Необходимо также очистить кеш от базы данных между запросами, чтобы получить правильные результаты при вызове ToList(). Отделите построение запроса от материализации и отметьте их. –
OrderBy, похоже, не учитывается во втором запросе. Это может быть причиной разницы. Вы можете попробовать «... от s в порядке пользователей по u.LastName, u.FirstName ...» – jbl