AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Subselect mit mehreren Rückgabewerten
Thema durchsuchen
Ansicht
Themen-Optionen

Subselect mit mehreren Rückgabewerten

Ein Thema von Jasocul · begonnen am 27. Jan 2014 · letzter Beitrag vom 27. Jan 2014
Antwort Antwort
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
jobo

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

AW: Subselect mit mehreren Rückgabewerten

  Alt 27. Jan 2014, 10:14
Da sind relativ viele ... in Deinem SQL, also kann man nur raten.

Ich würde versuchen, die Subselects in die From Clause des Hauptstatements zu packen. Geht vor allem dann-vielleicht in einem Rutsch-, wenn die Where Clauses der 3 Subselects eigentlich identisch sind und tatsächlich nur das summierte Feld variiert.

Subselects im Select Teil sind m.E. das Letzte was ich machen würde. Viele RDBMS können das "mittlerweile", aber klassisch gehört bzw. kommt es ins "from". Was ich damit sagen will, wenn dabei schlechte Laufzeiten rauskommen, dann weil das Statement mit Subselects im Select Teil vom "Optimizer" nicht oder nur stiefmütterlich oder total bescheuert aufgelöst wird.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#3

AW: Subselect mit mehreren Rückgabewerten

  Alt 27. Jan 2014, 10:16
Du könntest etwas in dieser Art versuchen

Code:
Select t1.*,t2.SUMX1,t2.SUMX2,t2.SUMX3
from Tabelle1 t1
join
(Select LinkField,Sum(FeldX1) as SUMX1,Sum(FeldX2) as SUMX2,Sum(FeldX3) as SUMX3
from Tabelle2 
Group by LinkField
) t2
on t1.LinkField=t2.LinkField
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)

Geändert von Bummi (27. Jan 2014 um 10:20 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Jasocul
Jasocul

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

AW: Subselect mit mehreren Rückgabewerten

  Alt 27. Jan 2014, 10:27
Argh. Dabei war das Wochenende doch gar nicht so anstrengend.
Habe es jetzt in die Where-Klausel verlegt.

Eine Woche, die mit einem Montag anfängt, kann einfach nicht gut sein.

Danke für den schnellen Denkanstoß.
Peter
  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 16:28 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