Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Berechnetes Feld in SQL einbauen (https://www.delphipraxis.net/211412-berechnetes-feld-sql-einbauen.html)

Smiley 12. Sep 2022 11:15

Datenbank: MSAccess • Version: 1808 • Zugriff über: FireDAC

Berechnetes Feld in SQL einbauen
 
Hallo Community
Könnt ihr mir bei folgendem Problem helfen.

Ich habe
eine Tabelle Kunden mit den Feldern Nachname,Vorname,Ort,Gebiet
eine Tabelle Gebiete mit den Feldern Nr,Name
eine Tabelle KuMi mit KdNr und AngNr

In der KuMi (Kunden/Mitarbeiter) Tabelle sind gleiche KdNr mit mehreren AngNr eingetragen 1:n

Jetzt möchte ich alle Kunden aus Gebiet lGebiet (Übergabewert), auflisten und alle AngNummern die diesem Kunden zugeiesen sind , in der Tabelle KuMi, in ein Berechnetes Stringfeld eintragen, mit Komma getrennt.

Die Ausgabe eines Datensatzes sollte dann etwa so aussehen:
Mustermann Max Wuestenrode 12,45,22

Im Moment läuft die Ausgabe mit folgender SQL-Abfrage in DM.qWork:
Code:
'Select Nachname,Vorname,Ort,Gebiet from Kunden Where Gebiet = ' + IntToStr(lGebiet) + 'and passiv=false order by Nachname';
grdKunde.Columns[4].Visible := False; // Gebiet ausblenden
Jetzt möchte ich dort einbauen, dass ich alle Angestellten in einem String, als berechnetes Feld einfüge.
Die Calkulation des Strings könnte im Ereignis OnCalcFields gemacht werden.

In OnCalcFields dann:
Übergabeparameter lKdNr : Integer;
Code:
DM.qW2.SQL.Text :='Select KdNR,AngNr from KuMi Where KdNr='+IntToStr(lKdNr);
DM.qW2.Open;

DM.qW2.First;
lAngString:='';
While not DM.qW2.Eof Do
    begin
      if lAngString='' then
      lAngString:=lAngString + DM.qW2.FieldByName('AngNr').AsString
      else
      lAngString:=lAngString + ','+DM.qW2.FieldByName('AngNr').AsString;
      DM.qW2.Next;
    end;
Das lAngString soll dann im DBGrid grdKunde dem Kalkulierten Stringfeld zugewiesen werden.

Frage:
Wie kann ich das Kalkulierte Feld in die SQL-Anweisung einbringen für das grdKunden
oder eine neue Query qGebietsListeK anlegen und diese anzeigen. (Möglichst im Code (SQL)).
Wie mache ich es am Besten für jeden Kunden in DM.qWork alle AngNummer aus der KuMi Liste in die GebietsListe einzubauen (lAngString).


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:19 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