![]() |
Datenbank: Firbird • Version: 2,5,5 • Zugriff über: IBO / IBExpert
SQL Statement brigt doppelte Summen
Hallo,
ich habe folgendes SQL Statement: select p.patientnr , p.suchwort , p.GebuehSatz , sum (b.gesamtbetrag) as summe , sum (b2.gesamtbetrag) as bezahlt from tbl_patient p join tbl_patient p2 on p2.gehoertzu = p.patientnr join tbl_patblatt b on b.gehoertzu = p.patientnr and b.typ <> 'Z' left join tbl_patblatt b2 on b2.gehoertzu = p.patientnr and b2.typ = 'Z' where p.sammeladresse = 'J' and b.tierenr is null and b2.tierenr is null group by p.patientnr , p.suchwort , p.GebuehSatz Das Ergebnis der Spalten Summe und Bezahlt ist falsch. Hier wird mir immer der doppelte Wert angezeigt. Kann jemand erkennen wo mein Fehler ist. |
AW: SQL Statement brigt doppelte Summen
Also, ohne die Daten zu kennen, ist das ein bisschen schwierig.
Irgendetwas führt dazu, dass du die Daten doppelt bekommst. Am einfachsten wirst du es sehen, wenn du die Daten ohne Aggregation ansiehst. Ein join ist mir aber aufgefallen: join tbl_patient p2 on p2.gehoertzu = p.patientnr Soweit ich das sehen kann, wird nichts aus p2 irgendwo verwendet. Also theoretisch überflüssig und vielleicht sogar dein Fehler. |
AW: SQL Statement brigt doppelte Summen
hallo,
also wenn du immer das doppelte rausbekommst, wie du eigentlich haben möchtest, brauchst du doch das Ergebnis einfach nur durch 2 teilen und schon stimmt die Kasse wieder.:stupid: (Problem verstanden, Problem gelöst). Ansonsten verstehe ich diesen Abschnitt gar nicht:
Delphi-Quellcode:
Einmal soll der Typ<>'Z' sein und dann machst du einen zweiten join auf die gleiche Tabelle mit Typ='Z'???
on p2.gehoertzu = p.patientnr
join tbl_patblatt b on b.gehoertzu = p.patientnr and b.typ <> 'Z' left join tbl_patblatt b2 on b2.gehoertzu = p.patientnr and b2.typ = 'Z' mfg |
AW: SQL Statement brigt doppelte Summen
Sind eventuell immer in der Tabelle tbl_patient p2 immer zwei datensätze zu einem zugeordnet? weil dann bekommst du jeden Datensatz doppelt heraus.
|
AW: SQL Statement brigt doppelte Summen
Hallo Devil1925,
das stimmt es können x beliebige Datensätze zu p gehören. (Im jetzigen Fall gehörten 2 Kunden einer Sammeladresse an.) Hierbei geht es darum das viele Kunden einer Rechnungssammeladresse zugeordnet sind. Die Positionen der einzelnen Kunden liegen in der tbl_Patplatt. |
AW: SQL Statement brigt doppelte Summen
kommt denn der richtige wert heraus, wenn du die Tabelle P2 nicht mehr mit anjoinst? denn diese wird ja nirgens sonst in deinem SQL erwähnt, wenn ich das richtig sehe...
|
AW: SQL Statement brigt doppelte Summen
Hallo Devil1925,
stimmt habe den join weggelassen nun passt es. Viel Dank.:thumb: |
AW: SQL Statement brigt doppelte Summen
Nur einmal gejoint und dann beim SUM entscheiden was gezählt wird?
SQL-Code:
Wenn es jetzt noch doppelt ist, dann ist vermutlich einer der beiden JOINs dafür verantwortlich.
select p.patientnr, p.suchwort, p.GebuehSatz,
sum(iif(b.typ <> 'Z', b.gesamtbetrag, null)) as summe, -- Summe über alles? sum(b.gesamtbetrag) as summe, sum(iif(b.typ = 'Z', b.gesamtbetrag, null)) as bezahlt from tbl_patient p join tbl_patient p2 on p2.gehoertzu = p.patientnr join tbl_patblatt b on b.gehoertzu = p.patientnr where p.sammeladresse = 'J' and b.tierenr is null group by p.patientnr, p.suchwort, p.GebuehSatz Irgendwie so?
SQL-Code:
select p.patientnr, p.suchwort, p.GebuehSatz,
sum(iif(b.typ <> 'Z', b.gesamtbetrag, null)) as summe, sum(iif(b.typ = 'Z', b.gesamtbetrag, null)) as bezahlt from tbl_patient p join tbl_patblatt b on b.gehoertzu = p.patientnr where (p.sammeladresse = 'J' and b.tierenr is null) or p.patientnr in (select p2.patientnr from tbl_patient where p2.gehoertzu = p.patientnr) group by p.patientnr, p.suchwort, p.GebuehSatz Müsste bei
Delphi-Quellcode:
nicht b2.gesamtbetrag genommen werden, statt b.gesamtbetrag? (gejoint gegen p2)
join tbl_patient p2 on p2.gehoertzu = p.patientnr
|
AW: SQL Statement brigt doppelte Summen
hat sich wohl erldeigt
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:07 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz