Rangordna efter högsta medelvärde

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • bigsky
    Medlem
    • 2002-05-02
    • 825

    #1

    Rangordna efter högsta medelvärde

    Använder MySQL, tabeller:

    restaurants
    - restaurant_id
    - district_id
    - restaurant_name

    visits
    - visit_id
    - restaurant_id
    - date_visited
    - tot_1_4

    Kolumnerna restaurant_id är förstås relaterade till varandra. I tabellen visits förekommer samma restaurant_id flera gånger, dock med olika datum i date_visited och olika summor i tot_1_4.

    Det jag vill göra är:

    - Få fram ett medelvärde av tot_1_4 för varje restaurangs alla förekomster i tabellen visits.
    - Rangordna de 5 restauranger som har högst medelvärde så att det skrivs ut t ex:

    1. Restaurang B 88%
    2. Restaurang A 70%
    3. Restaurang L 55%
    4. Restaurang D 45%
    5. Restaurang C 13%
  • clarkbones
    Medlem
    • 2001-02-07
    • 2693

    #2
    Liet svårt att veta hur du lagrat data i fältet tot_1_4, men här kommer något du kan utgå ifrån.

    Fråga 1:
    SELECT AVG(tot_1_4) AS Betyg, R.Restaurant_ID,restaurant_name
    FROM Restaurants R
    INNER JOIN Visits V ON R.Restaurant_ID=V.Restaurant_ID
    GROUP BY R.Restaurant_ID,restaurant_name

    Fråga 2:
    SELECT TOP 5 * FROM
    (
    SELECT AVG(tot_1_4) AS Betyg, R.Restaurant_ID,restaurant_name
    FROM Restaurants R
    INNER JOIN Visits V ON R.Restaurant_ID=V.Restaurant_ID
    GROUP BY R.Restaurant_ID,restaurant_name
    ) TABBY
    ORDER BY Betyg DESC
    Microsoft Certified Application Developer

    Comment

    • bigsky
      Medlem
      • 2002-05-02
      • 825

      #3
      Datan i tot_1_4 är sparad som tvåsiffriga tal t ex. 88 med typ tinyint(11), default 0.

      Comment

      • clarkbones
        Medlem
        • 2001-02-07
        • 2693

        #4
        Dåså, då ska min lösning funka!
        Microsoft Certified Application Developer

        Comment

        • bigsky
          Medlem
          • 2002-05-02
          • 825

          #5
          Grymt! Stort tack. Använde fråga 2 och bytte ut TOP 5 mot LIMIT 5 eftersom jag kör MySQL.

          Comment

          • bigsky
            Medlem
            • 2002-05-02
            • 825

            #6
            Följdfråga: Hur skulle frågan se ut om jag vill ta reda på vilken plats varje restaurangs betyg har i relation till de övriga restaurangernas betyg och sätta den platsen i parantes enl. nedan?

            T ex:

            Restaurang B 88% (1)
            Restaurang A 70% (3)
            Restaurang L 55% (29)
            Restaurang D 45% (32)
            Restaurang C 13% (47)

            Comment

            • clarkbones
              Medlem
              • 2001-02-07
              • 2693

              #7
              Hmm, vad menar du med "vilken plats varje restaurangs betyg har i relation till de övriga restaurangernas betyg "?
              Microsoft Certified Application Developer

              Comment

              • bigsky
                Medlem
                • 2002-05-02
                • 825

                #8
                Jag tänkte att om 88% är det högsta värdet då blir det ju plats 1. Och t ex. 13% är det 47 högsta värdet av alla restaurangers betyg så blir det ju plats 47.

                Comment

                • clarkbones
                  Medlem
                  • 2001-02-07
                  • 2693

                  #9
                  Jo, men vi har ju sorterat på betyg och vi visar bara de fem översta så i detta exempel så blir placeringen 1-5 i vårt exempel(?) Har jag fattat rätt?

                  Om det är det du vill lösa så finns det RANK
                  http://thinkdiff.net/mysql/how-to-ge...g-mysql-query/
                  Microsoft Certified Application Developer

                  Comment

                  • bigsky
                    Medlem
                    • 2002-05-02
                    • 825

                    #10
                    Jag var nog otydlig. De är egentligen två listor jag ska göra. I den andra listan ska alla restauranger skrivas ut och där sorteras ordningen på namn och inte efter betyg. Där vill jag skriva ut vilken plats varje enskild restaurangs betyg har.
                    Det finns väl inget i koden ovan enligt SQL-fråga två som innehåller betygets platsnummer på listan?

                    Comment

                    Working...