php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 28.06.2005, 07:41  
Gast
 
Beiträge: n/a
Standard Mysql Abfrage über 3 Tabellen in Verbidung mit COUNT()

Hallo liebe PHP Freund(e/in),

ich habe dieFrage schon in einem andrem Forum erfragt und hoffe mir das ihr mir vielleicht helfen könnt.

Ich hab ein mittelschweres Problem, stellt euch vor ich habe 3 Tabellen, die erste beinhaltet Benutzerdaten und zwei die anderen beiden daten für diese Nutzer. Es muss nicht jeder Benutzer Daten in der 2. und 3. Tabelles besitzen, nur weil er als Nutzer in der 1. Tabelle hinterlegt ist.

Mein Frage ist nun wie kann ich mit nur einer Sql Query die Benutzerdaten auslesen + die Menge (also Count) der vorkommen Datensätze des Benutzer in der 2. und 3. Tabelle. Es sollen aber auch Benutzer angezeigt werden, die zum Beispiel keine Daten in beiden Tabelle vorhanden besitzen.

Einfach Struktur

1. Tabelle - Benutzer
id
Name
Adresse

2. Tabelle - Lose
Los_id
Benutzer_id
Preis

3. Tabelle - Tranche
Tranche_id
Benutzer_id

Nun sollen erstmal alle Benutzer aufgelistet werden, falls sie noch Lose besitzen die Menge und die Summe aller + die Menge der Tranchen falls vorhanden, wenn nicht dann nur die Benutzerdaten.

Bitte helft mit!
Danke Christian
  Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 28.06.2005, 07:43  
Gast
 
Beiträge: n/a
Standard

versuchs mal so:
Code:
SELECT
   Benutzer.id,
   Benutzer.name,
   COUNT(Lose.Los_id) AS anzahl_lose,
   COUNT(Tranche.Tranche_id) AS anzahl_tranchen
FROM
   Benutzer
LEFT JOIN
   Lose ON (Benutzer.id = Lose.Benutzer_id)
LEFT JOIN
   Tranche ON (Benutzer.id = Tranche.Benutzer_id)
GROUP BY
   Benutzer.id
ORDER BY
   Benutzer.id
- ohne Gewähr -
mfG
dilemma
  Mit Zitat antworten
Alt 28.06.2005, 09:44  
Gast
 
Beiträge: n/a
Standard

Es funktioniert.
DANKE DANKE!

Christian.
  Mit Zitat antworten
Alt 28.06.2005, 11:09  
Gast
 
Beiträge: n/a
Standard

Ein kleines Problem habe ich noch.. irgendwie werden durch den zweiten Count befehl die Werte vom im Ersten mit addiert.


Mein Query:

SELECT t1.id,t1.name,SUM(t3.gewinn) as gewinn,COUNT(t4.id) as tranchen FROM benutzer as t1 LEFT JOIN auslosung_lose as t2 ON (t1.id = t2.benutzer_id) LEFT JOIN optionen_sofortgewinne as t3 ON (t2.sofortgewinn_id = t3.id) LEFT JOIN tranchen as t4 ON (t1.id = t4.benutzer_id) WHERE t1.rechte = '3' GROUP BY t1.id ORDER BY t1.rechte,t1.id

Erläuterung

t1 = Benutzer
t2 = Lose (Tabelle besitzt Benutzer id und Gewinn id)
t3 = Gewinne (Tabelle besitz verschiedene Preise)
t4 = Tranchen (Gewinnpackete)

Ergebnis

Irgenwie wird durch t4 die Anzahl des Count übelst hoch gezählt..

Ich weiss das Problem ist sehr kompley villeicht habtihr ne Idee wie ich weiter kommen könnte..

Danke Christian.
  Mit Zitat antworten
Alt 28.06.2005, 11:38  
Gast
 
Beiträge: n/a
Standard

Versuchs mal so:
Code:
SELECT
   t1.id,
   t1.name,
   SUM(t3.gewinn) as gewinn,
   COUNT(t4.id) as tranchen
FROM
   benutzer as t1
LEFT JOIN auslosung_lose as t2
   ON (t1.id = t2.benutzer_id
       AND
       t1.rechte = '3')
LEFT JOIN optionen_sofortgewinne as t3
   ON (t2.sofortgewinn_id = t3.id)
LEFT JOIN tranchen as t4
   ON (t1.id = t4.benutzer_id
       AND
       t1.rechte = '3')
GROUP BY t1.id
ORDER BY t1.rechte,t1.id
ohne Gewähr
~dilemma~
  Mit Zitat antworten
Alt 28.06.2005, 12:56  
Gast
 
Beiträge: n/a
Standard

danke für die antwort.
irgendwie multiplziert mir der count() und sum() ergebins, für die summe der gewinne.

danke
christian.
  Mit Zitat antworten
Alt 28.06.2005, 14:04  
Gast
 
Beiträge: n/a
Standard

eventuell:
Mit zusätzlicher WHERE-Definition, so:
Code:
SELECT
   t1.id,
   t1.name,
   SUM(t3.gewinn) as gewinn,
   COUNT(t4.id) as tranchen
FROM
   benutzer as t1
LEFT JOIN auslosung_lose as t2
   ON (t1.id = t2.benutzer_id
       AND
       t1.rechte = '3')
LEFT JOIN optionen_sofortgewinne as t3
   ON (t2.sofortgewinn_id = t3.id)
LEFT JOIN tranchen as t4
   ON (t1.id = t4.benutzer_id
       AND
       t1.rechte = '3')
WHERE
   t2.benutzer_id IS NOT NULL
   AND
   t4.benutzer_id IS NOT NULL
   AND
   t3.id IS NOT NULL
GROUP BY t1.id
ORDER BY t1.rechte,t1.id
ohne Gewähr
~dilemma~

ansonsten bin ich überfragt.
  Mit Zitat antworten
Alt 28.06.2005, 16:18  
Gast
 
Beiträge: n/a
Standard

Danke für deine Hilfe, funzt leider nicht. Da ich bischen Zeitdruck habe nutze ich erstmal eine unsaubere Variante (diviere die summe durch die tranche,um die summe zu erhalten)

christian.
  Mit Zitat antworten
Alt 29.06.2005, 04:15  
Gast
 
Beiträge: n/a
Standard

Du hast nicht MySQL 4.x ? Sondern eher 3.x ? Bei 3.0 ist das Problem über mehrere COUNTs bekannt. Mir jedenfalls. =)
  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
PHP Array in MYSQL Tabellen schreiben Matt Datenbanken 1 26.02.2008 19:43
[Erledigt] MYSQL Tabellen konvertieren. Datenbanken 1 11.04.2006 08:16
MySQL Abfrage über 2 Tabellen Datenbanken 4 21.03.2006 11:44
MySQL Abfrage aus 3 Tabellen funzt nicht! c-bass Datenbanken 6 17.01.2006 10:12
komplizierte mysql abfrage php_frage PHP Tipps 2007 5 28.12.2005 17:55
Abfrage mehrerer Tabellen per PHP (Code vereinfachen) PHP Tipps 2007 4 18.12.2005 12:34
Mysql Abfrage über 3 Tabellen in Verbidung mit COUNT() PHP Tipps 2005-2 4 28.06.2005 07:47
[Erledigt] MySQL Abfrage aus mehreren Tabellen Datenbanken 1 12.04.2005 17:53
Frage zur MySQL Abfrage Datenbanken 5 04.02.2005 12:31
[Erledigt] MySQL: Abfrage mit Statistikauswertung Datenbanken 3 13.08.2004 11:51
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
Abfrage über 3 Tabellen PHP Tipps 2004 3 31.07.2004 22:34
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 abfrage count andere tabelle, http://www.php.de/datenbanken/25589-mysql-abfrage-ueber-3-tabellen-verbidung-mit-count.html, mysql join 3 tabellen, mysql abfrage über drei tabellen, sql count drei tabellen, mysql count mehrere tabellen, summen aus 2 mysql tabellen, mysql abfrage count, mysql left join count mit mehreren tabellen, mysql join sum count, mysql join count andere tabelle, mysql sql sort by count in anderer tabelle, mysql summe und count 2 tabellen, mysql abfrage mit count in zweiter tabelle, mysql 2 tabellen left join addieren, php abfrage von 3 tabellen in 2 datenbanken, mysql join summe merhere tabellen, mysql left join 3 tabellen und count, sql count in zwei tabellen zusammenzählen, php abrage 2count summe

Alle Zeitangaben in WEZ +1. Es ist jetzt 21: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.