AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL : select mit Fallabfrage
Thema durchsuchen
Ansicht
Themen-Optionen

SQL : select mit Fallabfrage

Ein Thema von baumina · begonnen am 21. Jun 2013 · letzter Beitrag vom 24. Jun 2013
Antwort Antwort
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#1

AW: SQL : brauche Hilfe bei Abfrage

  Alt 21. Jun 2013, 10:49
Die Funktion gibt es schon.
http://dev.mysql.com/doc/refman/5.0/...ction_greatest
Du kannst ja die Selects verschachteln, der eine Parameter der greatest Funktion wäre einfach die 0.
Gruß, Jo

Geändert von jobo (21. Jun 2013 um 10:51 Uhr) Grund: rote Box..
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: SQL : brauche Hilfe bei Abfrage

  Alt 21. Jun 2013, 11:00
Ja danke, ich werds am Montag mit GREATEST versuchen, indem ich folgende 2 Werte mitgeb:
1. 0
2. den select

das müsst doch klappen.
Hinter dir gehts abwärts und vor dir steil bergauf ! (Wolfgang Ambros)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: SQL : brauche Hilfe bei Abfrage

  Alt 21. Jun 2013, 11:03
Die Funktion gibt es schon.
http://dev.mysql.com/doc/refman/5.0/...ction_greatest
Du kannst ja die Selects verschachteln, der eine Parameter der greatest Funktion wäre einfach die 0.
Irgendwie war mir auch so, aber ... ich war wohl blind
... ich müsste den lesl-select aber auch 2mal ausrühren?
Nein, der SELECT wird nicht mehrfach ausgeführt, denn es werden die Werte übergeben.

SQL-Code:
SELECT GREATEST( 0,
         (coalesce(sum(sl.Anzahl),0) -
          coalesce((SELECT sum(lesl.Anzahl)
                      FROM TBLLESL lesl
                     WHERE sl.plmartid=lesl.plmartid
                       AND au.auid=lesl.auid
                  GROUP BY lesl.PLMARTID),0))
       ) AnzFehlt
FROM TBLAUPLM au
LEFT JOIN TBLPLMAUSL sl
       ON au.plmauid=sl.plmauid
WHERE sl.BuchTyp is NULL
  AND au.auid=:AUID
  AND sl.PLMARTID=:PLMARTID
GROUP BY sl.PLMARTID
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (21. Jun 2013 um 11:35 Uhr)
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#4

AW: SQL : brauche Hilfe bei Abfrage

  Alt 21. Jun 2013, 11:09
ich war wohl blind
Ein Wunder!!


Und ja, gemeint war, Du >kannst< Selects verschachteln, >musste< aber hier nicht.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: SQL : brauche Hilfe bei Abfrage

  Alt 21. Jun 2013, 11:36
ich war wohl blind
Ein Wunder!!


Und ja, gemeint war, Du >kannst< Selects verschachteln, >musste< aber hier nicht.
Ich bin wohl auch wochenendreif

Meinen Beitrag habe ich editiert, damit der Bezug klarer wird
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#6

AW: SQL : select mit Fallabfrage

  Alt 21. Jun 2013, 17:26
Die Unterabfrage ist nicht sauber:
SQL-Code:
SELECT sum(lesl.Anzahl)
                      FROM TBLLESL lesl
                     WHERE sl.plmartid=lesl.plmartid
                       AND au.auid=lesl.auid
                  GROUP BY lesl.PLMARTID)
Durch das GROUP BY können potentiell mehrere Datensätze entstehen.
Wegen der Verwendung als Unterabfrage ist aber hier nur ein Datensatz erlaubt.
Die GROUP BY Klausel muss da weg.
fork me on Github
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: SQL : select mit Fallabfrage

  Alt 21. Jun 2013, 20:37
Durch das GROUP BY können potentiell mehrere Datensätze entstehen.
Wegen der Verwendung als Unterabfrage ist aber hier nur ein Datensatz erlaubt.
Die GROUP BY Klausel muss da weg.
Das versteh ich jetzt aber echt nicht. Wie soll ich denn sonst an meine Sum(Anzahl) kommen wenn nicht über GROUP BY?
Hinter dir gehts abwärts und vor dir steil bergauf ! (Wolfgang Ambros)
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#8

AW: SQL : select mit Fallabfrage

  Alt 21. Jun 2013, 23:38
Das da sieht eventuell nach CASE aus. Da lässt sich IF THEN ELSE jedenfalls einsetzen. Stichwort : Kreuztabelle/Pivot-Tabelle.
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#9

AW: SQL : select mit Fallabfrage

  Alt 22. Jun 2013, 00:39
Wie soll ich denn sonst an meine Sum(Anzahl) kommen wenn nicht über GROUP BY?
Ohne GROUP BY wird natürlich auch eine Summe gebildet und zwar die Summe über alle Datensätze die durch die WHERE-Bedingung angesprochen werden.
Vereinfacht gesagt wird ohne GROUP BY alles in einen Topf summiert.
Mit GROUP BY können mehrere Töpfe (=Datensätze) entstehen wobei jeder Topf seine eigene Teilsumme hat.

Beispieltabelle
Code:
Farbe  | Preis
==================
rot    | 5.0
grün   | 10.0
blau   | 15.0
rot    | 22.0
SQL-Code:
SELECT Sum(Preis) FROM Beispieltabelle
-- Ergebnis: 1 Datensatz Inhalt: 52.0
SQL-Code:
SELECT Sum(Preis) FROM Beispieltabelle
GROUP BY Farbe
-- Ergebnis: 3 Datensätze Inhalt:
-- 15.0
-- 10.0
-- 27.0
Man sieht aber dass diese Ergebnistabelle ziemlich sinnlos ist weil der Bezug zu dem Group-By-Feld verloren gegangen ist.
Deshalb sind die Felder aus der Group-By-Klausel eigentlich immer in der Feldliste enthalten:
SQL-Code:
SELECT Farbe, Sum(Preis) FROM Beispieltabelle
GROUP BY Farbe
-- Ergebnis: 3 Datensätze Inhalt:
-- blau | 15.0
-- grün | 10.0
-- rot | 27.0
Würde man jetzt alle diese Teilsummen aufsummieren dann kommt man wieder auf die Gesamtsumme von 52.0.
fork me on Github
  Mit Zitat antworten Zitat
Antwort Antwort


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 23:41 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