AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Trigger zur Laufzeit Syntax ?
Thema durchsuchen
Ansicht
Themen-Optionen

Trigger zur Laufzeit Syntax ?

Ein Thema von haentschman · begonnen am 26. Nov 2007 · letzter Beitrag vom 26. Nov 2007
Antwort Antwort
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.298 Beiträge
 
Delphi 12 Athens
 
#1

Trigger zur Laufzeit Syntax ?

  Alt 26. Nov 2007, 11:41
Datenbank: Firebird • Version: 2.0 • Zugriff über: Zeos
Hallo alle miteinander...

nach Stunden des Suchens und Probierens möchte ich Euch mal wieder belästigen

Ich möchte zur Laufzeit einen Trigger in die Tabelle eintragen.

- die Syntax des Triggers in der Tabelle ist klar...
- der Generator ist erstellt...
- die Tabelle ist erstellt

so soll der Trigger in der Tabelle ankommen...

Delphi-Quellcode:
create trigger ANLAGEN_BI for ANLAGEN active before INSERT Position 0
 as
   begin
     if (new.id is null) then
       new.id = gen_id(idfeld_gen,1)
   end
und damit habe ich es aus der Anwendung heraus versucht...

Delphi-Quellcode:
DMDB.ZQueryDiv.SQL.Text:= 'create trigger ANLAGEN_BI for ANLAGEN active before INSERT Position 0 as ';
DMDB.ZQueryDiv.SQL.Add('begin ');
DMDB.ZQueryDiv.SQL.Add('if (new.id is null) then ');
DMDB.ZQueryDiv.SQL.Add('new.id = gen_id(idfeld_gen,1) ');
DMDB.ZQueryDiv.SQL.Add('end');
DMDB.ZQueryDiv.ExecSQL;
...der Compiler meckert immer über das End in Zeile 5

...viel kann es nicht sein... aber ich habe schon diverse Varianten probiert wie QuotedStr etc.

Danke für Eure Hilfe...
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.298 Beiträge
 
Delphi 12 Athens
 
#2

Re: Trigger zur Laufzeit Syntax ?

  Alt 26. Nov 2007, 11:52
...warum komme ich immer erst darauf, wenn ich schon gepostet habe...

... in meinem Code fehlte ein ';' in Zeile 4

Delphi-Quellcode:
DMDB.ZQueryDiv.SQL.Text:= 'create trigger ANLAGEN_BI for ANLAGEN active before INSERT Position 0 as ';
DMDB.ZQueryDiv.SQL.Add('begin ');
DMDB.ZQueryDiv.SQL.Add('if (new.id is null) then ');
DMDB.ZQueryDiv.SQL.Add('new.id = gen_id(idfeld_gen,1); ');
DMDB.ZQueryDiv.SQL.Add('end');
DMDB.ZQueryDiv.ExecSQL;
  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 01:37 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