Einzelnen Beitrag anzeigen

Benutzerbild von Jasocul
Jasocul

Registriert seit: 22. Sep 2004
Ort: Delmenhorst
1.355 Beiträge
 
Delphi 11 Alexandria
 
#1

Subselect mit mehreren Rückgabewerten

  Alt 27. Jan 2014, 10:04
Datenbank: MS-SQL • Version: 2003 • Zugriff über: Direkt
Ich habe eine Abfrage mit ein paar Joins und 3 Subselects, welche mir Summen aus einer identischen Abfrage liefern.
Also etwa so:
Code:
select Feld1,
       Feld2,
       Feld3,
       (Select Sum(FeldX1) from ... where ...) as X1,
       (Select Sum(FeldX2) from ... where ...) as X2,
       (Select Sum(FeldX3) from ... where ...) as X3
  from Tabelle1
       join Tabelle2
...
Wie schon gesagt, sind die Subselects identisch bis auf das Feld, das summiert werden soll. Außerdem haben diese im "where" einen Bezug zur Hauptabfrage. Leider ist dieser so unpassend, dass kein "group by" über die Hauptabfrage möglich ist.

Die Abfrage braucht ca. 2 Sekunden bei 5 Datensätzen. Das liegt nicht nur (aber auch) an den Subselects. Mich stört es trotzdem, dass ich für nahezu identische Abfragen 3 mal die Datenbank bemühen muss.

Gibt es irgendeine Möglichkeit die Subselects zusammenzufassen und 3 Rückgabewerte zu liefern?
Peter
  Mit Zitat antworten Zitat