Oprettet ons. d. 25. august 2010 kl. 11:35:15

iwerksom
iwerksom (3.200 point. Point ude: 90)

Linq - fra INNER join til LEFT join

Hej Eksperter
Jeg kæmper med LINQ og specielt dens join syntax.
Har følgende Inner join som jeg gerne vil have lavet om til en Left JOIN så alle entries fra OrdreList kommer med.

public static IEnumerable<OrderList> SelectFullOrderListByPeriod(int LånerNr, int PeriodID)
    {
        return Table
            .Where(m => m.TilLånerNr == LånerNr)
            .Where(m => m.period_id == PeriodID)
            .Join(
            tblMatKøb.Table,
            m => m.Indeks_i_MiP,
            k => k.Indeks_i_MiP,
            (m, k) => new OrderList { BestillingsDato = m.BestillingsDato, FaktBeløb = m.FaktBeløb, OrdreNummer = m.OrdreNummer, OrdreType = m.OrdreType, Total = (m.FaktBeløb + k.MatPris) });
       
    }

Er der nogen som kan hjælpe mig at skrive ovenstående query om?
På forhånd tak.

Skrevet ons. d. 25. august 2010 kl. 18:15:47| #1

arne_v
arne_v (1.005.623 point)
Ifoelge den her skal du bruge en Group Join:

http://www.developer.com/ (...)

Skrevet ons. d. 25. august 2010 kl. 22:44:09| #2

iwerksom
iwerksom (3.200 point)
burde der ikke være en nemmere måde at gøre det?
Eller skal Linq bare være besværligt når man vil lave andet end en simpelt SELECT?

Skrevet ons. d. 25. august 2010 kl. 23:05:23| #3

buzzzz
buzzzz (46.576 point)
ifyoudo.net
Du kan jo bare lave SQL :-)

Men ja, left join er noget crap ... synes jeg også selv, men tænk på hvor mange problemer det også løser for dig :-)

Kig på NHibernate, tror de har en meget nemmere måde at lave det på, det er en lidt mere moden ORM.

Skrevet lør. d. 28. august 2010 kl. 23:32:28| #4

arne_v
arne_v (1.005.623 point)
JOIN i koden er noget hø med ORM.

JOIN skal laves af ORM når den loader objekterne.

Skrevet man. d. 30. august 2010 kl. 09:42:22| #5

iwerksom
iwerksom (3.200 point)
kan man få den til at lave andet end inner join med entity association?

Skrevet man. d. 30. august 2010 kl. 10:51:59| #6

buzzzz
buzzzz (46.576 point)
ifyoudo.net
Hvad tænker du på ?

Skrevet man. d. 30. august 2010 kl. 15:36:49| #7

iwerksom
iwerksom (3.200 point)
Noget i retning af

MyDatabaseDataContext db = new MyDatabaseDataContext();
var matKøb = db.tblMatkøb.Single( m => m.Indeks_i_MIP == Indeks_i_MIP);
var query = OrderList

For på den måde at udnytte relationen mellem de to tabeller. Så jeg får den række fra tblMatKøb som svarer til min række i tblOrder(OrderList)

Skrevet man. d. 30. august 2010 kl. 22:26:54| #8

buzzzz
buzzzz (46.576 point)
ifyoudo.net
left, outer og alle specielt joins er wag som arne_v skrev.

NHibernate er i hvert fald den næste ORM jeg ville kigge på, der er nogen uber fede ting.

Men LINQ2SQL har vist ikke mange-til-mange relationer som virker godt ...

mvh

Skrevet søn. d. 26. september 2010 kl. 20:54:19| #9

arne_v
arne_v (1.005.623 point)
Tid at få afsluttet her?

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Koordinater for nyt vindue efter scroll, csharp.

Oprettet den 11. februar 2012 kl. 01.54
bjarnefilm giver 30 point for svar | Giv et svar »

Treeview hovedmenu á lá Dynamics C5

Oprettet den 10. februar 2012 kl. 08.12
olehaahr giver 30 point for svar | Giv et svar »

Deployment på Windows Mobile 6.5

Oprettet den 9. februar 2012 kl. 13.59
schristensen giver 200 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger