AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

Offene Frage von "Rainbow6"
Ein Thema von juergen · begonnen am 8. Jul 2020 · letzter Beitrag vom 8. Jul 2020
Antwort Antwort
Seite 2 von 2     12
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
7.825 Beiträge
 
Delphi 10.4 Sydney
 
#11

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 15:20
Hiermit werden nun wieder mehrere Zeilen pro Tag und pro Person angezeigt. Wenn ich BA.AUFTRAGTEXT entferne funktioniert alles und es wird nur eine Zeile pro Tag und Pro Person ausgewiesen.
Wenn besagte Person an einem Tag an mehreren Aufträgen gearbeitet hat, ist das ja auch logisch. Was soll denn bei Auftragtext stehen, wenn es pro Tag dann trotzdem nur eine Zeile sein soll?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
951 Beiträge
 
Delphi 10.3 Rio
 
#12

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 17:34
Was soll denn bei Auftragtext stehen, wenn es pro Tag dann trotzdem nur eine Zeile sein soll?
Der aggregierte Datensatz (BN.Total_Std) hat die RecID zu der Tabelle BA.Auftragstext.
Vermutlich muss BA.Auftragstext in einem Subselect ausgeführt werden, wo BA.AuftragsNr = BN.AuftragsNummer ist.
Dann lande ich aber wieder bei meiner Eingangsfrage, da mir dann dass SSMS anzeigt, dass er die Spalte vom Subselect in der group by-Klausel nicht kennt.
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
7.825 Beiträge
 
Delphi 10.4 Sydney
 
#13

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 18:46
Der aggregierte Datensatz (BN.Total_Std) hat die RecID zu der Tabelle BA.Auftragstext.
Da scheinst du was falsch zu verstehen. Der aggregierte Datensatz entspricht keinem der Datensätze der Tabelle. Er enthält nur die aggregierten Feldwerte (hier MAX(BN.Total_Std)) und die Felder aus GROUP BY. Insofern gibt es diese RecID überhaupt nicht in dem RecordSet.

Offenbar möchtest du den Datensatz aus BN, dessen Total_Std-Wert für eine Person und ein Datum dem Maximum in diesem Bereich entspricht. Das wäre aber ein ganz andere Query. Es ist auch nicht sicher, daß es nur einen einzigen Datensatz mit diesem Kriterium gibt. Die Person könnte an einem Tag auch für zwei Aufträge die gleiche Stundenzahl gearbeitet haben, die dann diesem Max-Wert entspricht. Dann gibt es keinen eindeutigen Datensatz mit diesem Max-Wert.

Die Anforderungen sind irgendwie noch nicht vollständig spezifiziert.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Rainbow6

Registriert seit: 21. Mai 2019
16 Beiträge
 
#14

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 21:05
Servus,

also bei komplexen SQL Selects hilft häufig WITH - damit kannst du dir vorher aggregierte Werte aufbauen, so dass du alle JOIN's dann schonmal auf dem gleichen Level hast. Außerdem kannst du dir die einzelnen temporären Tabellen vorher ansehen.

Grüße
Daniel
  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:12 Uhr.
Powered by vBulletin® Copyright ©2000 - 2020, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2020 by Daniel R. Wolf