Avatar billede brian0905 Nybegynder
18. maj 2009 - 22:17 Der er 3 kommentarer og
1 løsning

Hjælp til link query, gruppering

Jeg har tre tabeller i min database. Jeg benytter Linq 2 sql. Mine tabeller er: Kategori, gruppe og link.

:Kategori
-navn etc

:Gruppe
-navn etc
-kategoriid

:Link
-navn
-antalbesøg
-gruppeid

Som man kan se er der en klar forbindelse mellem dem. Jeg vil nu gerne lave en query der kan give mig top 5 kategorier, hvis links har været mest besøgt (højest antalbesøg). Det vil sige de mest populære kategorier. Nogle der har et bud?
Avatar billede erle Nybegynder
18. maj 2009 - 22:38 #1
Din database giver altså ingen mening.

Hvad er forbindelsen mellem link og gruppeid? og hvad med gruppe til kategori? Kan slet ikke finde den.

Eks:
:kategori
kategoriid
navn

:gruppe
gruppeid
navn
kategoriid

:link
linkid
navn
antalbesog
gruppeid

SELECT a.navn FROM kategori a, gruppe b, link c WHERE c.gruppeid=b.gruppeid AND b.kategoriid=a.kategoriid
ORDER BY c.antalbesog LIMIT 5

Mit bud:D
Avatar billede arne_v Ekspert
18. maj 2009 - 23:04 #2
Her er en lille demo med kategori og link som LINQ to objects:

using System;
using System.Collections.Generic;
using System.Linq;

namespace E
{
    public class Kategori
    {
        public int Id { get; set; }
        public string Navn { get; set; }
    }
    public class Link
    {
        public String Navn { get; set; }
        public int Antal { get; set; }
        public int Kategori { get; set; }
    }
    public class Program
    {
        public static void Main(string[] args)
        {
            List<Kategori> kats = new List<Kategori>();
            kats.Add(new Kategori { Id=1, Navn="K1" });
            kats.Add(new Kategori { Id=2, Navn="K2" });
            kats.Add(new Kategori { Id=3, Navn="K3" });
            kats.Add(new Kategori { Id=4, Navn="K4" });
            kats.Add(new Kategori { Id=5, Navn="K5" });
            kats.Add(new Kategori { Id=6, Navn="K6" });
            List<Link> links = new List<Link>();
            links.Add(new Link { Navn="A", Antal=3, Kategori=2 });
            links.Add(new Link { Navn="B", Antal=2, Kategori=1 });
            links.Add(new Link { Navn="C", Antal=4, Kategori=3 });
            links.Add(new Link { Navn="D", Antal=5, Kategori=2 });
            links.Add(new Link { Navn="E", Antal=1, Kategori=4 });
            links.Add(new Link { Navn="F", Antal=7, Kategori=5 });
            links.Add(new Link { Navn="G", Antal=6, Kategori=1 });
            links.Add(new Link { Navn="H", Antal=4, Kategori=2 });
            var q = (from k in kats join l in links on k.Id equals l.Kategori
                    group l by k.Navn into g
                    orderby g.Sum(l => l.Antal) descending
                    select new { Navn=g.Key, Antal=g.Sum(l => l.Antal)}).Take(3);
            foreach(var r in q)
            {
                Console.WriteLine(r.Navn + " " + r.Antal);
            }
            Console.ReadKey();
        }
    }
}

Den maa kunne tilrettes til LINQ for SQL og dine tabeller.
Avatar billede brian0905 Nybegynder
20. maj 2009 - 08:29 #3
Takker Arne, det fik mig sporet ind på det rigtige
Avatar billede arne_v Ekspert
22. maj 2009 - 18:45 #4
saa smider jeg et svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester