Bu sorgunun linq sorgu sözdizimini kullanarak yöntem tabanlı bir sözdizimine dönüştürmeye çalışıyorum.Sorgu sözdizimini kullanmadan Entity Framework'te sol dış birleştirme nasıl yapılır?
var products = context.Products
.Join(inner: context.TopSellings.DefaultIfEmpty(),
outerKeySelector: c => c.Id, innerKeySelector: y => y.Id,
resultSelector: (j, k) => new { Name = j.Name, Rating = k.Rating == null ? 0 : k.Rating })
.OrderByDescending(p => p.Rating);
ve:
{SELECT
[Project1].[Id] AS [Id],
[Project1].[Name] AS [Name],
[Project1].[C1] AS [C1]
FROM (SELECT
[Extent1].[Id] AS [Id],
[Extent1].[Name] AS [Name],
CASE WHEN ([Extent2].[Rating] IS NULL) THEN 0 ELSE [Extent2].[Rating] END AS [C1],
[Extent2].[Rating] AS [Rating]
FROM [dbo].[Products] AS [Extent1]
LEFT OUTER JOIN [dbo].[TopSellings] AS [Extent2] ON [Extent1].[Id] = [Extent2].[Id]
) AS [Project1]
ORDER BY [Project1].[Rating] DESC}
Bugüne kadar ne denedim böyle bir şeydir:
var products = from p in context.Products
join t in context.TopSellings
on p.Id equals t.Id into g
from tps in g.DefaultIfEmpty()
orderby tps.Rating descending
select new
{
Name = p.Name,
Rating = tps.Rating == null ? 0 : tps.Rating
};
sorgu yukarıda bu sql sorgusu üretir: Burada
sorgu var Bu, farklı bir sql sorgusu üretir (Hangi veriyi bei olduğu konusunda elbette farklı bir anlamı vardır) Programda kullanılan ng):{SELECT
[Project1].[Id] AS [Id],
[Project1].[Name] AS [Name],
[Project1].[C1] AS [C1]
FROM (SELECT
[Extent1].[Id] AS [Id],
[Extent1].[Name] AS [Name],
CASE WHEN ([Join1].[Rating] IS NULL) THEN 0 ELSE [Join1].[Rating] END AS [C1]
FROM [dbo].[Products] AS [Extent1]
INNER JOIN (SELECT [Extent2].[Id] AS [Id], [Extent2].[Rating] AS [Rating]
FROM (SELECT 1 AS X) AS [SingleRowTable1]
LEFT OUTER JOIN [dbo].[TopSellings] AS [Extent2] ON 1 = 1) AS [Join1] ON [Extent1].[Id] = [Join1].[Id]
) AS [Project1]
ORDER BY [Project1].[C1] DESC}
Cevabınız çok yardımcı olacaktır ve çok teşekkür ederiz!
Bu tür dönüşümler bana anlamsız, ama yine de, eşdeğer yöntem sözdizimi GroupJoin' SelectMany' 'tarafından takip' kullanmak istiyorsunuz, oradan kendiniz yapabilirsiniz umuyoruz. –
Bkz. Msdn: https://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b – jdweng
@IvanStoev, salt öğrenme amaçlıdır. –