我正在尝试在Entity Framework中加入几个表。表中的一个关系是一对多关系。
E.g。对象Person有一个对象DATA列表,但是当我在实体框架中包含该表时,它只返回select子句中的单个DATA项。
查询如下所示:
from persoon in PagedView.Context.PERSOON
join verhuring in PagedView.Context.VERHURINGEN
.Where(
x => x.DatumGeldigTot == null || x.DatumGeldigTot >= OverzichtPersonenSearch.ReferentieDatum)
on persoon.ComputerNr equals verhuring.PersoonsID into a
from verhuring in a.DefaultIfEmpty()
join eenheid in PagedView.Context.EENHEID
on verhuring.Eenheid equals eenheid.ComputerNr into b
from eenheid in b.DefaultIfEmpty()
join data in PagedView.Context.DATA
on persoon.ComputerNr equals data.COMPUTERNR into c
from data in c.DefaultIfEmpty()
select new PersoonDto
{
ComputerNr = persoon.ComputerNr,
EIGENREF = persoon.EIGENREF,
NAAM = persoon.NAAM,
ADRES = persoon.ADRES,
LANDCODE = persoon.LANDCODE,
POSTNR = persoon.POSTNR,
TELEFOON = persoon.TELEFOON,
EMAIL = persoon.EMAIL,
RIJKSREGISTER = persoon.RIJKSREGISTER,
SOORT_PERSOON = persoon.SOORT_PERSOON,
GESLACHT = persoon.GESLACHT,
DATUM = persoon.DATUM,
FAMILIENAAM = persoon.FAMILIENAAM,
VOORNAAM = persoon.VOORNAAM,
STRAAT = persoon.STRAAT,
NR = persoon.NR,
BUSNR = persoon.BUSNR,
Website = persoon.Website,
IsActief = persoon.IsActief,
Verhuringen = persoon.Verhuringen,
POSTNRS = persoon.POSTNRS,
BANKREKENING_IBAN = persoon.BANKREKENING_IBAN,
GEBOORTELAND = persoon.GEBOORTELAND,
GEBOORTEPLAATS = persoon.GEBOORTEPLAATS,
GEBOORTEDATUM = persoon.GEBOORTEDATUM,
BANKREKENINGOGM = persoon.BANKREKENINGOGM,
Nationaliteit = persoon.Nationaliteit,
DUBIEUZEHUURDER = persoon.DUBIEUZEHUURDER,
BEROEP = persoon.BEROEP,
Een = eenheid,
DATA = data // HERE IT FAILS, BECAUSE DATA IS OF TYPE ICOLLECTION<DATA> WHILE data IS A SINGLE OBJECT
}
答案 0 :(得分:1)
问题是您已通过解压缩组将组连接转换为左连接。 GroupJoin返回您想要的集合。
var x = document.createElement("A");
var t = document.createTextNode("Festival Website");
x.setAttribute("href", url);
x.appendChild(t);
infowincontent.appendChild(x);