![]() |
Datenbank: ADS • Version: 10 • Zugriff über: UniDAC
Update / Insert über mehrere Tabellen
Hallo,
ich habe eine Tabelle (z.B. "Mitarbeiter") die mit meheren anderen Tabellen in Verbindung steht (z.B. Mitarbeiter_Zusatz, Mitarbeiter_Akte etc). Die Verknüpfung der Tabellen ist 1:1. Wenn nun ein neuer Mitarbeiter angelegt wird soll natürlich auch in den verknüpften Tabellen die dazueghörigen Datensätze angelegt werden, und bei einem Update sollen sie upgedated werden. Ist es möglich, das mit Datenbankkomponenten zu erledigen, oder muß das von Hand erledigt werden? |
AW: Update / Insert über mehrere Tabellen
Hallo,
Sowas würde denke ich mal mit Triggern funktionieren. |
AW: Update / Insert über mehrere Tabellen
Zitat:
SQL-Code:
oder aber über einen Trigger:
Insert into Mitarbeiter (id, feld1) values (10,'test');
insert into mitarbeiter_zusatz(id, feld1) values(10,'irgendwas'); insert into mitarbeiter_Akte(id, feld1) values(10,'irgendwas anderes');
SQL-Code:
aber: warum ist das nötig? Ich würde die Zusatz-Tabellen nur füllen, wenn diese wirklich benötigt werden. Statt INNER JOINS dann OUTER JOINS verwenden und es tut nicht weh, falls mal ein Mitarbeiter nicht in den Zusatz-Tabellen gefunden wird (ist eh anzuraten!).
create trigger trig_ins on mitarbeiter after insert
begin insert into mitarbeiter_zusatz(id) select id from __new; insert into mitarbeiter_Akte(id) select id from __new; end; Statt einem Update könntest Du dann im Programm ein MERGE verwenden:
SQL-Code:
MERGE mitarbeiter_zusatz on id=10
WHEN MATCHED THEN UPDATE SET feld1=wert1,feld2=wert2 WHEN NOT MATCHED THEN INSERT(id,feld1,feld2) VALUES(10,wert1,wert2); |
AW: Update / Insert über mehrere Tabellen
Ich würde die Datensätze nicht automatisch anlegen, dann könntest du deren Felder auch gleich in die "Haupttabelle" aufnehmen
|
AW: Update / Insert über mehrere Tabellen
Vielen Dank für die schnellen Antworten.
Also wie es scheint sind die VCL-Komponenten für den Datenbankzugriff für solche Geschichten nicht ausgelegt... Aber das mit dem Merge hört sich sehr interessant an, werde ich mir mal genauer ansehen. |
AW: Update / Insert über mehrere Tabellen
Hallo,
bai FibPlus gibt es das TFIBUpdateObject, dass u.a. folgendes bietet: Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:06 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz