Oprettet man. d. 29. september 2008 kl. 10:12:00

zentral
zentral (8.425 point. Point ude: 3.300)
www.zentral.dk

Brug af groupe by LINQ

Hej Hej...

Jeg kunne godt tænke mig at hente 12 højest bedømte drinks ud af min db... og jeg kan bar ikke få det til og virke


database diagrammet kan ses her...
http://www.zentral.dk/ (...)

jeg har lave en metode som giver alle de rigtige id'er ud, men pga. at min forkerte forståelse af groupe by så er det også det eneste som kommer ud...

    public static IQueryable GetHighestRatedDrinks()
    {
        DataContactClassDataContext db = new DataContactClassDataContext();

        var resultat = from p in db.RatingArchives
                group p.Rating by new { p.DrinkID } into g
                select new
                {
                    ID = g.Key.DrinkID.Value
                };

        return resultat;
    }

Med denne metode får jeg alle id'er du på de højest bedømte, men jeg kan ikke få navnet ud også.. så laver den dubletter hvis i forstår...

Skrevet man. d. 29. september 2008 kl. 14:48:27| #1

montago
montago (25.871 point)
hvad med noget ala'


var resultat = from p in db.RatingArchives
                group p.Rating by new { p.DrinkID } into g
orderby g.Count() descending
                select new
                {
                    ID = g.Key.DrinkID.Value,
count = g.Count()
                };

foreach(var p in resultat.take(12) ){}

Skrevet man. d. 29. september 2008 kl. 14:49:49| #2

montago
montago (25.871 point)
i din new {} - kan du jo indsætte navnet, som du henter fra din Drinks tabel

        group p.Rating by new { p.DrinkID, navn = db.Drinks(d=>d.DrinkID).Navn } into g

Skrevet man. d. 29. september 2008 kl. 18:18:16| #3

zentral
zentral (8.425 point)
www.zentral.dk
montago, når jeg køre dette

        var resultat = from p in db.RatingArchives
                      group p.Rating by new { p.DrinkID, navn = db.Drinks(d => d.DrinkID).Navn } into g
                      orderby g.Count() descending
                      select new
                      {
                          ID = g.Key.DrinkID.Value,
                          Name = g.Key.navn,
                          count = g.Count()
                      };

        foreach (var p in resultat.Take(12)) { }

        return resultat;

så får jeg en fejl ved group:
Cannot convert lambda expression to type 'System.Collections.Generic.IEqualityComparer<AnonymousType#1>' because it is not a delegate type

og ved resultat. i foreach løkken:
The type arguments for method 'System.Linq.Queryable.Take<TSource>(System.Linq.IQueryable<TSource>, int)' cannot be inferred from the usage. Try specifying the type arguments explicitly.


hele metoden er en IQueryable

Skrevet man. d. 29. september 2008 kl. 20:09:18| #4

montago
montago (25.871 point)
hehe...

db.Drinks.Single( i stedet for db.Drink(
som jeg sagde... " noget ala' "


var resultat = from p in db.RatingArchives
                      group p.Rating by new { p.DrinkID, navn = db.Drinks.Single(d => d.DrinkID).Navn } into g
                      orderby g.Count() descending
                      select new
                      {
                          ID = g.Key.DrinkID.Value,
                          Name = g.Key.navn,
                          count = g.Count()
                      };

        foreach (var p in resultat.Take(12)) { }

        return resultat;

Skrevet man. d. 29. september 2008 kl. 20:09:54| #5

montago
montago (25.871 point)
jeg mangler lidt databasen / objecterne at side med... så det hele blev skrevet i hånden efter bedste evne

Skrevet man. d. 29. september 2008 kl. 21:26:30| #6

zentral
zentral (8.425 point)
www.zentral.dk
montago... hehe bare iorden det ska nok lykkes...
får samme fejl på group og denne fejl:

Linje 45:                      group p.Rating by new { p.DrinkID, navn = db.Drinks.Single(d => d.DrinkName).Navn } into g


Cannot implicitly convert type 'int' to 'bool'

Skrevet man. d. 29. september 2008 kl. 21:31:30| #7

montago
montago (25.871 point)
doh...

.Single() tager en Lamdba som skal give en Bool
defor:

group p.Rating by new {
  p.DrinkID,
  navn = db.Drinks.Single(
    d => d.DrinkName == p.DrinID
  ).Navn
} into g

umiddelbart har jeg ikke lige overblikket til at kunne sige, om vi gør tingene rigtigt... mest af alt, fordi dit diagram mangler RatingArchive tabellen

Skrevet man. d. 29. september 2008 kl. 21:32:41| #8

montago
montago (25.871 point)
og selvfølgelig skal Propertien lige ændres til

.DrinkName

-->

db.Drinks.Single(
    d => d.DrinkName == p.DrinID
  ).DrinkName

som den står på tabellen

Skrevet man. d. 29. september 2008 kl. 21:34:21| #9

montago
montago (25.871 point)
prøver igen:

group p.Rating by new {
  p.DrinkID,
  navn = db.Drinks.Single(
    d => d.DrinkID == p.DrinkID  //<-- havde 2 fejl her
  ).Navn
} into g

Skrevet tir. d. 30. september 2008 kl. 14:44:46| #10

zentral
zentral (8.425 point)
www.zentral.dk
mange tak for hjælpen .!!. bestod svendeprøven med 10 tal.!.
så kom med et svar, du har virkelig fortjent mine points...

Skrevet tir. d. 30. september 2008 kl. 20:26:01| #11

montago
montago (25.871 point)
hihi... bestod du eller jeg :-D  ?

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

Login controller med eksisterende database

Oprettet den 26. januar 2012 kl. 10.37
faran giver 60 point for svar | Giv et svar »

Session og klient

Oprettet den 24. januar 2012 kl. 09.49
badal giver 30 point for svar | Giv et svar »

Få vist billeder via sti i XML fil

Oprettet den 15. januar 2012 kl. 16.09
Counx giver 100 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