web-dev-qa-db-fra.com

Requête Entity Framework pour jointure interne

Quelle serait la requête pour:

select s.* from Service s 
inner join ServiceAssignment sa on sa.ServiceId = s.Id
where  sa.LocationId = 1

dans un cadre d'entité?

Voici ce que j'ai écrit:

 var serv = (from s in db.Services
                join sl in Location on s.id equals sl.id
                where sl.id = s.id
                select s).ToList();

mais c'est faux. Quelqu'un peut-il me guider sur le chemin?

58
TheWebs
from s in db.Services
join sa in db.ServiceAssignments on s.Id equals sa.ServiceId
where sa.LocationId == 1
select s

db est votre DbContext. La requête générée ressemblera à (exemple pour EF6):

SELECT [Extent1].[Id] AS [Id]
       -- other fields from Services table
FROM [dbo].[Services] AS [Extent1]
INNER JOIN [dbo].[ServiceAssignments] AS [Extent2]
    ON [Extent1].[Id] = [Extent2].[ServiceId]
WHERE [Extent2].[LocationId] = 1
88
Sergey Berezovskiy

Si vous êtes intéressé par la syntaxe de la méthode, si vous avez une propriété de navigation, c'est très simple:

db.Services.Where(s=>s.ServiceAssignment.LocationId == 1);

Si vous ne le faites pas, à moins qu'il y ait une Join() substitution dont je ne suis pas au courant, je trouve que ça a l'air plutôt bizarre (et que je suis un puriste de la syntaxe Method):

db.Services.Join(db.ServiceAssignments, 
     s => s.Id,
     sa => sa.ServiceId, 
     (s, sa) => new {service = s, asgnmt = sa})
.Where(ssa => ssa.asgnmt.LocationId == 1)
.Select(ssa => ssa.service);
49
Michael Blackburn

Vous pouvez utiliser une propriété de navigation si elle est disponible. Il produit une jointure interne dans le code SQL.

from s in db.Services
where s.ServiceAssignment.LocationId == 1
select s
6
The Lonely Coder