Próbuję dołączyć do trzech stołów, ale nie rozumiem metody ...
Skończyłem dołączyć do 2 stołów
var entryPoint = dbContext.tbl_EntryPoint
.Join(dbContext.tbl_Entry,
c => c.EID,
cm => cm.EID,
(c, cm) => new
{
UID = cm.OwnerUID,
TID = cm.TID,
EID = c.EID,
}).
Where(a => a.UID == user.UID).Take(10);
Chciałbym dołączyć tabelę tbl_Title z TID PK i uzyskać pole Tytuł .
Wielkie dzięki
c#
entity-framework
entity-framework-4
entity-framework-5
entity-framework-4.1
Erçin Dedeoğlu
źródło
źródło
Odpowiedzi:
Nie jest to testowane, ale uważam, że składnia powinna działać w przypadku zapytania lambda. Gdy łączysz więcej tabel za pomocą tej składni, musisz zagłębiać się w nowe obiekty, aby osiągnąć wartości, którymi chcesz manipulować.
var fullEntries = dbContext.tbl_EntryPoint .Join( dbContext.tbl_Entry, entryPoint => entryPoint.EID, entry => entry.EID, (entryPoint, entry) => new { entryPoint, entry } ) .Join( dbContext.tbl_Title, combinedEntry => combinedEntry.entry.TID, title => title.TID, (combinedEntry, title) => new { UID = combinedEntry.entry.OwnerUID, TID = combinedEntry.entry.TID, EID = combinedEntry.entryPoint.EID, Title = title.Title } ) .Where(fullEntry => fullEntry.UID == user.UID) .Take(10);
źródło
Myślę, że będzie łatwiej używając zapytania opartego na składni:
var entryPoint = (from ep in dbContext.tbl_EntryPoint join e in dbContext.tbl_Entry on ep.EID equals e.EID join t in dbContext.tbl_Title on e.TID equals t.TID where e.OwnerID == user.UID select new { UID = e.OwnerID, TID = e.TID, Title = t.Title, EID = e.EID }).Take(10);
I prawdopodobnie powinieneś dodać
orderby
klauzulę, aby upewnić się, żeTop(10)
zwraca prawidłowe dziesięć pierwszych pozycji.źródło