php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 12.08.2004, 16:19  
Gast
 
Beiträge: n/a
Standard [Erledigt] MySQL: Abfrage mit Statistikauswertung

Hallo.

Da ich bis jetzt nur einfache SQL-Abfragen und Befehle hatte, stolpere ich nun über meinen ersten komplizierteren Befehl.

Ich möchte gern eine Scorerstatistik für Eishockey erstellen und hab dazu folgende Tabellen (Ausschnitt: Original ist viel umfangreicher - brauch nur das Prinzip):

tbl_spieler
- Spieler_ID
- Name
- Vorname
- Nr

tbl_tore
- Tor_ID
- Torschuetze (Verweis auf Spieler_ID)
- Assist1 (Verweis auf Spieler_ID)
- Assist2 (Verweis auf Spieler_ID)

tbl_strafen
- Strafen_ID
- Spieler (Verweis auf Spieler_ID)

Am Ende möchte alle Spieler aus der Tabelle tbl_spieler (die eine bestimmte Bedingung dort erfüllen, aber das kommt später) mit Namen, Vornamen, Nr, die Anzahl der Tore, die Anzahl der Vorlagen (Summe aus Assist1 + Assist2) und die Punkte (Summe aus Tore, Assist1 und Assist2) und das ganze geordnet nach Punkten, dann Toren, dann Assist und möglichst in einer SQL-Abfrage, da es eben dann einfacher auszuwerten geht. Zur besseren Übersicht:

Ergebnis soll sein (wird dann in PHP realisiert, ist aber nicht bestandteil meines Problems):
Nr | Name | Vorname | Tore | Vorlagen | Punkte

Mein derzeitiges (My)SQL-Statement dazu lautet:
SELECT tbl_spieler.Name, tbl_spieler.Vorname, COUNT( tbl_tore.Torschuetze ) AS Tore, COUNT( tbl_tore.Assist1 ) + COUNT( tbl_tore.Assist2 ) AS Vorlagen, COUNT( tbl_tore.Torschuetze ) + COUNT( tbl_tore.Assist1 ) + COUNT( tbl_tore.Assist2 ) AS Punkte

FROM tbl_spieler, tbl_tore

WHERE tbl_spieler.Spieler_ID = tbl_tore.Torschuetze

GROUP BY tbl_spieler.Spieler_ID

ORDER BY Punkte DESC , Tore DESC , Vorlagen DESC

Es liefert allerdings nur die richtigen Werte bei den Toren und außerdem nicht alle notwendigen Spieler, d.h. Spieler ohne Tore in der tbl_tore fehlen gänzlich.

Wie muss es richtig heißen? Wäre über jede Hilfe super dankbar!

MfG Torsten P
  Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 13.08.2004, 09:59  
18inch
Gast
 
Beiträge: n/a
Standard

Ich denke, dass in der Tabelle tore nur Spieler gespeichert sind, die auch ein Tor geschossen haben, Oder???
Deswegen gibt er auch nur Spieler aus die schon ein Tor auf Ihrem Konto verbuchen können.
Oder liege ich da falsch?

Sind nur die Torergebnisse richtig?? Sind die Assists falsch??
  Mit Zitat antworten
Alt 13.08.2004, 10:34  
Erfahrener Benutzer
 
Benutzerbild von lazydog
 
Registriert seit: 02.04.2008
Beiträge: 4.032
lazydog befindet sich auf einem aufstrebenden Ast
Standard

Wenn du auch die Spieler ohne Punkte haben willst, brauchst du einen LEFT JOIN:
Code:
SELECT s.Name, s.Vorname, 
    COUNT( t.Torschuetze ) AS Tore, 
    COUNT( t.Assist1 ) + COUNT( t.Assist2 ) AS Vorlagen, 
    COUNT( t.Torschuetze ) + COUNT( t.Assist1 ) + COUNT( t.Assist2 ) AS Punkte
FROM tbl_spieler s
LEFT JOIN tbl_tore t on s.Spieler_ID = t.Torschuetze
GROUP BY s.Spieler_ID
ORDER BY Punkte DESC , Tore DESC , Vorlagen DESC
Etwa auf die Art müsste es gehen
__________________
Gruss
L
lazydog ist offline   Mit Zitat antworten
Alt 13.08.2004, 11:51  
Gast
 
Beiträge: n/a
Standard

Danke - auf LEFT JOIN bin ich jetzt auch gestossen. Funktioniert aber leider nur zum Teil. Habe auch meine Tabelle weiter normiert, d.h. es existiert nun auch ein tbl_assist1 und tbl_assist2.

Ich bleibe dran...
  Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
[Erledigt] MySql Frage: Problem mit einer etwas lomplexeren Abfrage tomtaz Datenbanken 5 24.06.2008 22:36
Frage: richtige SQL Abfrage von einer MySQL Spalte die SET werte besitzt Seb PHP Tipps 2008 2 29.05.2008 11:36
MySQL Abfrage von Ver. 5 für Ver 3. des MySQL Servers FireFIghter Datenbanken 3 02.02.2007 17:18
MySQL Abfrage macht Seite langsam Datenbanken 11 19.10.2006 19:38
MySQL - Abfrage: Unterschiedliche Ergebnisse aus PHP/manuell horstenpeter Datenbanken 3 16.07.2006 13:22
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
Abfrage bei mySQL 4 ApfeL Datenbanken 5 24.03.2006 18:53
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Suche Tipps für Persormance-Steigerung (Geld für Nützliches) Beitragsarchiv 18 16.08.2005 10:57
einfache mysql abfrage und mysql update haut nicht ganz hin djrace PHP Tipps 2005-2 6 12.08.2005 15:28
Mysql Abfrage Datenbanken 4 27.02.2005 22:26
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
MySQL mehrfach abfrage PHP Tipps 2004-2 3 22.11.2004 14:23
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
mysql abfragestatistik, mysql query statistik, http://www.php.de/datenbanken/6831-mysql-abfrage-mit-statistikauswertung.html, php mysql vorlagen, mysql statistik, mysql vorlagen, mysql abfrage statistik, mysql statistik abfragen, mysql statistiken abfragen, mysql statistiken, php sql statistik, statistik auswertung php, statistische auswertung sql, statistik php mysql, mysql statistische abfrage, statistikauswertung mit php, sql query statistik count, php mysql vorlage, statistik abfrage mysql, mysql spaltensumme

Alle Zeitangaben in WEZ +2. Es ist jetzt 10:22 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.