AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken C# Trigger Before Insert/Update wird nicht ausgeführt, wieso?
Thema durchsuchen
Ansicht
Themen-Optionen

Trigger Before Insert/Update wird nicht ausgeführt, wieso?

Ein Thema von Jürgen Thomas · begonnen am 27. Nov 2007 · letzter Beitrag vom 27. Nov 2007
Antwort Antwort
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#1

Trigger Before Insert/Update wird nicht ausgeführt, wieso?

  Alt 27. Nov 2007, 10:12
Datenbank: Firebird • Version: 2.0 • Zugriff über: Firebird Net Provider
Hallo,

ich habe in meiner Datenbank einen Trigger Before Insert and Update vorgemerkt:
SQL-Code:
begin
  if ( New.Id IS NULL)
  then New.Id = GEN_ID(Zebu_Aendg_ID, 1);
END
Die ID ist der PrimaryKey; der Trigger ist aktiv; der Generator existiert. Aber sowohl aus meinem Programm heraus als auch durch IBExpert scheitert der folgende Befehl mit der Fehlermeldung "Verletzung der Eindeutigkeit bei ID":
SQL-Code:
INSERT INTO Zebu_Aendg ( PLZ, St1Name, St1Kz)
     SELECT PLZ, ZBGName, ZBGKenn
       FROM Quelle_Zebu q
      WHERE ( Leitraum = :Leitraum )
          AND ( SELECT COUNT(*) FROM Zebu z WHERE q.Plz = z.Plz ) = 0;
Wenn ich den Generator direkt einbaue, funktioniert es:
SQL-Code:
INSERT INTO Zebu_Aendg ( ID, PLZ, St1Name, St1Kz)
     SELECT GEN_ID(ZEBU_AENDG_ID,1), PLZ, ZBGName, ZBGKenn
  /* usw. alles andere unverändert */
Was kann ich übersehen haben? (Eigentlich weiß ich genau genug, wie ich mit Generatoren und Triggern verfahren muss, aber hier...) Danke! Jürgen
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Trigger Before Insert/Update wird nicht ausgeführt, wies

  Alt 27. Nov 2007, 10:21
Ist der Trigger aktiv?
Ist ID wirklich NULL?
Markus Kinzler
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#3

Re: Trigger Before Insert/Update wird nicht ausgeführt, wies

  Alt 27. Nov 2007, 12:22
Zitat von mkinzler:
Ist der Trigger aktiv?
Ja; so wird es auch von IBExpert angezeigt.
Zitat:
Ist ID wirklich NULL?
Durch den INSERT-Befehl wurde ID nicht mit einem Wert belegt (siehe Code-Auszug). Also müsste es so gelten.

Aber diese Nachfrage bringt mich (vermutlich) auf die Lösung: Die ID ist definiert mit einer Domain:
CREATE DOMAIN D_ID AS INTEGER DEFAULT 0 NOT NULL Dies hat FB wahrscheinlich zuerst ausgewertet. Ich werde deshalb den Trigger so ändern:
SQL-Code:
begin
  IF ( New.Id IS NULL OR New.Id = 0)
  THEN New.Id = GEN_ID(Zebu_Aendg_ID, 1);
END
Danke! Jürgen

PS. Dieses Problem war ein Beispiel für Betriebsblindheit: ich habe mich in meinen Gedanken festgerannt.
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  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 07:33 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