AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Anfängerfrage: TRIGGER - Andere Tabelle aktualisieren
Thema durchsuchen
Ansicht
Themen-Optionen

Anfängerfrage: TRIGGER - Andere Tabelle aktualisieren

Ein Thema von erich.wanker · begonnen am 15. Apr 2019 · letzter Beitrag vom 15. Apr 2019
Antwort Antwort
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
460 Beiträge
 
Delphi XE4 Professional
 
#1

Anfängerfrage: TRIGGER - Andere Tabelle aktualisieren

  Alt 15. Apr 2019, 13:50
Datenbank: Firebird • Version: 2.5 • Zugriff über: ZeosLib
Annahme:

Eine "Kundentabelle" mit Feld RECORD_NUMBER und NAME
Eine "Overviewtabelle" mit Feld PARENT_NAME und PARENT_NR

Ein Kunde kann x-mal in der Overviewtabelle verlinkt sein... (Kundentabelle.RECORD_NUMBER-Overviewtabelle.PARENT_NR)

Jetzt ist absichtlich (ist natürlich techn. falsch..) der Name des Kunden auch in der Overviewtabelle..

Ich überlege gerade wie ein Trigger aussehen müsste, der bei Änderungen oder Neuerstellen in der Kundentabelle die mehrfach vorhandenen Overviewtabelle-Einträge aktualisiert


Mein Pseudocode schau mal so aus:

Delphi-Quellcode:
CREATE TRIGGER UpdateVerknuepfung
FOR Kundentabelle
BEFORE INSERT OR UPDATE
AS
BEGIN

  if (exists(select * FROM Overviewtabelle WHERE PARENT_NR = new.RECORD_NUMBER))
  then
  begin
    Overviewtabelle.PARENT_NAME = new.NAME
  end
END
Ist das richtig? - irgendwie fehlt mir ein "while not EOF" -Ding

Danke für Hinweise
Erich
Erich Wanker - for life:=1971 to lebensende do begin ..
O
/H\
/ \
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Anfängerfrage: TRIGGER - Andere Tabelle aktualisieren

  Alt 15. Apr 2019, 13:59
Grundsätzlich sieht eine Schleife in PL/SQL so aus
SQL-Code:
for select
      <Feldliste>
    from
      <Tabelle>
    where
      <Bedingung>
    into <Variablen> do
begin
end
In Deinem Fall aber eher
SQL-Code:
update
  OverviewTabelle
set
  PARENT_NAME = new.NAME
where
   WHERE PARENT_NR = new.RECORD_NUMBER;
Markus Kinzler
  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 13:15 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