如何在实体框架中加入一对多关系?

时间:2017-03-01 14:37:23

标签: c# entity-framework linq

我正在尝试在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
                }

1 个答案:

答案 0 :(得分:1)

问题是您已通过解压缩组将组连接转换为左连接。 GroupJoin返回您想要的集合。

var x = document.createElement("A");
           var t = document.createTextNode("Festival Website");
            x.setAttribute("href", url);
            x.appendChild(t);
            infowincontent.appendChild(x);