AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Berechnetes Feld in SQL einbauen
Thema durchsuchen
Ansicht
Themen-Optionen

Berechnetes Feld in SQL einbauen

Ein Thema von Smiley · begonnen am 12. Sep 2022
Antwort Antwort
Benutzerbild von Smiley
Smiley

Registriert seit: 9. Dez 2004
Ort: Gedern
205 Beiträge
 
Delphi 10.4 Sydney
 
#1

Berechnetes Feld in SQL einbauen

  Alt 12. Sep 2022, 11:15
Datenbank: MSAccess • Version: 1808 • Zugriff über: FireDAC
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).

Geändert von Smiley (12. Sep 2022 um 14:06 Uhr)
  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 22:29 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