AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL : SUM Funktion mit Bedingungen für Felder

SQL : SUM Funktion mit Bedingungen für Felder

Ein Thema von Cronen · begonnen am 3. Jul 2014 · letzter Beitrag vom 3. Jul 2014
Antwort Antwort
Cronen

Registriert seit: 5. Sep 2003
Ort: Hannover
61 Beiträge
 
Delphi 10.3 Rio
 
#1

SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 16:37
Datenbank: ADS • Version: 11 • Zugriff über: local
Ich finde für ein SQL-Problem nicht den richtigen Ansatz. Als "SQL Legastheniker"
sind meine Suchen gescheitert (wahrscheinlich finde ich nur wieder nicht die
richtige Suchbegriffe ! )

Also das Problem:

Ich hab eine Tabelle mit den Spalten
[Rechnungsbetrag] [Anteil_A] [RechDatumTeilA] [Bezahlt_A] [Anteil_B] [RechDatumTeilB] [Bezahlt_B]

Ich möchte jetzt eine Auswertung der Tabelle mit der
1 Gesamtsumme
2 Summe Anteil A
3 Summe Bezahlt A
4 Summe Anteil B
5 Summe Bezahlt B
6 Summe RechnungTeilA und TeilB gestellt
7 Summe noch nicht in Rechnung gestellter Posten A + B

Felder 1 bis 5 sind kein Problem; nur 6 und 7 in der gleichen Abfrage krieg ich nicht hin
(seperat schon). In SQL sieht das für mich dann so aus:

Code:
SELECT
 SUM(Betrag) AS SummeGesamt,
 SUM(Anteil_A) AS SummeAnteilA,
 SUM(Bezahlt_A) AS SummeBezA,
 SUM(Anteil_B) AS SummeAnteilB,
 SUM(Bezahlt_B) AS SummeBezB,
 /* und jetzt haperts: */
 SUM(Anteil_A) "wenn RechDatum A = NULL" AS Ohne_Rechnungen + SUM(Anteil_B) "wenn RechDatum B = NULL" AS Ohne_Rechnungen,
 SUM(Anteil_A)"wenn RechDatum A <> NULL" AS Offene_Rechnungen + SUM(Anteil_B) "wenn RechDatum B <> NULL" AS Offene_Rechnungen
FROM
 Rechnungen;
Wie krieg ich die hier frei formulierten Bedingungen - also eine WHERE -Klausel nur für die einzelnen
Felder - in SQL hin? Kann mir jemand helfen ?
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#2

AW: SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 16:43
Ich verstehe ehrlich gesagt nicht mal deinen Pseudocode im SQL aber prinzipiell geht "iif" wenns das bei ADS gibt:

Code:
sum(iif(feld2 = 3, feld1, 0)) as summe
Summiert die werte für Feld für alle Datenzeilen wo Feld2 = 3 ist.
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.533 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 16:47
Falls es IIF nicht gibt, gibt es dann wenigstens CASE?
SQL-Code:
SELECT
  SUM(CASE WHEN Feld1 IS NULL THEN 0 ELSE Feld2 END)
FROM
  Tabelle
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
10.934 Beiträge
 
Delphi 12 Athens
 
#4

AW: SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 16:54
Das Stichwort heißt SubSelects.

Delphi-Quellcode:
SELECT
 SUM(Betrag) AS SummeGesamt,
 SUM(Anteil_A) AS SummeAnteilA,
 SUM(Bezahlt_A) AS SummeBezA,
 SUM(Anteil_B) AS SummeAnteilB,
 SUM(Bezahlt_B) AS SummeBezB,
 /* ungetestet */
 (SELECT SUM(Anteil_A) WHERE RechDatumTeilA IS NULL) + (SELECT SUM(Anteil_B) WHERE RechDatumTeilB IS NULL) AS Ohne_Rechnungen,
 (SELECT SUM(Anteil_A) WHERE not RechDatumTeilA IS NULL) + (SELECT SUM(Anteil_B) WHERE not RechDatumTeilB IS NULL) AS Offene_Rechnungen
FROM
 Rechnungen;
Ich weiß allerdings nicht ob ADS damit klar kommt.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#5

AW: SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 17:03
Da auch ich mit dem Pseudocode meine Probleme habe..
wie wäre es mit einem
Code:
Union
Code:
SELECT
  SUM(Betrag) AS SummeGesamt,
  SUM(Anteil_A) AS SummeAnteilA,
  SUM(Bezahlt_A) AS SummeBezA,
  SUM(Anteil_B) AS SummeAnteilB,
  SUM(Bezahlt_B) AS SummeBezB,
  0 AS Ohne_Rechnungen,
  0 as Offene_Rechnungen
FROM Rechnungen
Union
select
  0,
  0,
  0,
  0,
  0,
  SUM(Anteil_A) "wenn RechDatum A = NULL" AS Ohne_Rechnungen + SUM(Anteil_B) "wenn RechDatum B = NULL" AS Ohne_Rechnungen,
  SUM(Anteil_A)"wenn RechDatum A <> NULL" AS Offene_Rechnungen + SUM(Anteil_B) "wenn RechDatum B <> NULL" AS Offene_Rechnungen
 FROM
  Rechnungen;
ggf. das Ergebnis dann nochmal mit einen Group summieren

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector

Geändert von p80286 ( 3. Jul 2014 um 17:05 Uhr) Grund: TippFehler
  Mit Zitat antworten Zitat
Cronen

Registriert seit: 5. Sep 2003
Ort: Hannover
61 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: SQL : SUM Funktion mit Bedingungen für Felder

  Alt 3. Jul 2014, 17:19
Jawohl das sind Lösungen:

@ Neutral General und DeddyH:

- IIF funktioniert

@Uwe Raabe:

Genau das war das fehlende Stichwort:
Mit SubSelect habe ich auch sofort brauchbare Lösungen gefunden

Danke an alle !
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:09 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz