Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   select sum mit feldausgabe (https://www.delphipraxis.net/189831-select-sum-mit-feldausgabe.html)

HPB 27. Jul 2016 18:12

AW: select sum mit feldausgabe
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1343605)
Was ist für den Anfang mit

SQL-Code:
SELECT SUM(Zahlung), KontoArt
WHERE (KontoArt = 'E') or (KontoArt = 'A')
GROUP BY KontoArt
Das sollte doch schon mal die beiden Summen ergeben.

Bleibt immer noch unklar, was mit den übrigen Feldern gemeint ist.

Die beiden Summen werden ausgegeben.
Delphi-Quellcode:
select
sum(Zahlung) as Gesamt, KontoArt
Es werden die beiden Summen unter dem Feldnamen "Gesamt" ausgegeben,
jeweils mit der Kontoart 'E oder A'.
Aber wie greife ich auf die einzelnen Summe zu um sie anzuzeigen?


Ich werde das ganze für einen Fast-Report gebrauchen.
Der Report wird in etwa so aufgebaut sein:
Gruppenkopf: AuszugsNr, Beginn und Ende als Datum, und die Summe für den Auszug (Einzahlungen - Ausgabe)
Im Detail: Datum, KontoNr, Kontoname, Buchungstext, Zahlung.

Mit Gruß HPB

p80286 27. Jul 2016 18:20

AW: select sum mit feldausgabe
 
Falls in Kontoart nur 'A' oder 'E' steht reicht ein einfaches
Code:
SELECT SUM(Zahlung), KontoArt
GROUP BY KontoArt
Da ich mit
SQL-Code:
or
nixcht soo gute Erfahrungen gemacht habe schlage ich vor
[CODE=SQL]
Code:
SELECT SUM(Zahlung), KontoArt
where Kontoart='A'
GROUP BY KontoArt
Union
SELECT SUM(Zahlung), KontoArt
where Kontoart='E'
GROUP BY KontoArt
order by KontoArt
SQL-Code:
select
  sum(Zahlung) as Einnahme,
  sum(Zahlung) as Ausgabe,
  (select SUM(Einnahme) where KontoArt = 'E') as Ges_Einnahmen,
  (select SUM(Ausgabe= where KontoArt = 'A') as Ges_Ausgabe


 from KASSENBUCH
 where extract(year from datum) in (2016, 2016)
Gibt es die Felder "Einnahme" und "Ausgabe" in der Tabelle "Kassenbuch"?
Wenn ich mich richtig erinnere, nein!
Also versuch es mal mit
Code:
(select SUM(Zahlung) where KontoArt = 'E') as Ges_Einnahmen,
und wie schon weiter oben angemerkt
Code:
  sum(Zahlung) as Einnahme,
  sum(Zahlung) as Ausgabe,
wird in Einnahme und Ausgabe den selben Wert liefern.



Gruß
K-H

Aviator 27. Jul 2016 18:25

AW: select sum mit feldausgabe
 
Zitat:

Zitat von HPB (Beitrag 1343603)
SQL-Code:
select
 sum(Zahlung) as Einnahme,
 sum(Zahlung) as Ausgabe,
 (select SUM(Einnahme) where KontoArt = 'E') as Ges_Einnahmen,
 (select SUM(Ausgabe= where KontoArt = 'A') as Ges_Ausgabe --    <=== HIER IST DER FEHLER


from KASSENBUCH
where extract(year from datum) in (2016, 2016)
Bekomme beim Testen die Fehlermeldung: "Token unknow - line 4, column 23 - Where"
Der obige Code scheint zu funktionieren. Warum ich beim unteren Code
eine Fehlermeldung bekomme kann ich nicht nachvollziehen.
Mit Gruß HPB

Schau mal, da ist vor dem
SQL-Code:
WHERE KontoArt = 'A'
ein "=" Zeichen reingerutsch anstatt eine schließene Klammer ")". Ob das jetzt zum gewünschten Ergebnis führt kann ich nicht sagen, aber die Fehlermeldung sollte verschwinden.

HPB 27. Jul 2016 18:35

AW: select sum mit feldausgabe
 
Zitat:

Zitat von Aviator (Beitrag 1343614)
Zitat:

Zitat von HPB (Beitrag 1343603)
SQL-Code:
select
 sum(Zahlung) as Einnahme,
 sum(Zahlung) as Ausgabe,
 (select SUM(Einnahme) where KontoArt = 'E') as Ges_Einnahmen,
 (select SUM(Ausgabe= where KontoArt = 'A') as Ges_Ausgabe --    <=== HIER IST DER FEHLER


from KASSENBUCH
where extract(year from datum) in (2016, 2016)
Bekomme beim Testen die Fehlermeldung: "Token unknow - line 4, column 23 - Where"
Der obige Code scheint zu funktionieren. Warum ich beim unteren Code
eine Fehlermeldung bekomme kann ich nicht nachvollziehen.
Mit Gruß HPB

Schau mal, da ist vor dem
SQL-Code:
WHERE KontoArt = 'A'
ein "=" Zeichen reingerutsch anstatt eine schließene Klammer ")". Ob das jetzt zum gewünschten Ergebnis führt kann ich nicht sagen, aber die Fehlermeldung sollte verschwinden.

Danke für Deine Aufmerksamkeit.
Die schliessende Klammer fehlt in der Tat. Aber der Fehler tritt ja schon in der Zeile 4 beim "Where" auf.
Mit Gruß HPB

himitsu 28. Jul 2016 11:11

AW: select sum mit feldausgabe
 
Zitat:

SQL-Code:
(select SUM(Einnahme) where KontoArt = 'E') as Ges_Einnahmen,

Und von was soll bei
SQL-Code:
select SUM(Einnahme) where KontoArt = 'E'
das SUM angezeigt werden?

Da fehlt mindestens noch ein FROM dazwischen.


Zitat:

Aber wie greife ich auf die einzelnen Summe zu um sie anzuzeigen?
Ich klinke mich hier aus.
Nochmal will ich mich nicht wiederholen.

himitsu 28. Jul 2016 11:13

AW: select sum mit feldausgabe
 
[del] blöder Doppelpost

rokli 28. Jul 2016 11:45

AW: select sum mit feldausgabe
 
Moin!

Delphi-Quellcode:
sum(Zahlung) as Umsatz, -- alles zusammen
das ist aber leider falsch; wenn er zwei Arten von Buchungen hat, nämlich EIN- und AUS- Zahlungen, dann wirds nur richtig, wenn die Werte in den Buchungssätzen mit Vorzeichen versehen werden!

Wenn die Werte berechnet werden, wie Uwe Raabe es vorgegeben hat, dann kann man anschließend noch saldieren ...

Gruß Rolf

himitsu 28. Jul 2016 12:53

AW: select sum mit feldausgabe
 
Zitat:

Zitat von rokli (Beitrag 1343653)
das ist aber leider falsch; wenn er zwei Arten von Buchungen hat, nämlich EIN- und AUS- Zahlungen, dann wirds nur richtig, wenn die Werte in den Buchungssätzen mit Vorzeichen versehen werden!

Wurde dazu schon irgendwas gesagt? (kann mich nicht erinnern)

Aber auch da kann man die SUM für "Einzahlungen" und "Ausgabe" getrennt summieren und dann verrechnen (Einzahlungen-Ausgabe).
Und wenn die "Ausgaben" negativ sind, dann halt Einzahlungen+Ausgabe , bzw. man kann das dann problemlos mit einem SUM gemeinsam zusammenrechnen lassen.

rokli 28. Jul 2016 13:03

AW: select sum mit feldausgabe
 
@himitsu: Na klar, weil SUM ja nun mal "zusammenrechnet" :-D

ich würde es vielleicht so machen: (Edit: 3. SUM: dabei darf es aber nur diese beiden Kontenarten geben!)

Delphi-Quellcode:
SELECT
   SUM(CASE WHEN Kontoart = 'E' THEN Zahlung ELSE 0 END) AS Gesamt_Ein,
   SUM(CASE WHEN Kontoart = 'A' THEN Zahlung ELSE 0 END) AS Gesamt_Aus,
   SUM(CASE WHEN Kontoart = 'E' THEN Zahlung ELSE Zahlung * -1 END) AS Gesamt   
FROM
   Kassenbuch
wobei ich nicht weiss, ob diese Syntax von Interbase unterstützt wird.


Alle Zeitangaben in WEZ +1. Es ist jetzt 11:19 Uhr.
Seite 2 von 2     12   

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 by Thomas Breitkreuz