AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Trigger-"Übersetzung" (MySQL -> MSSQL)?
Thema durchsuchen
Ansicht
Themen-Optionen

Trigger-"Übersetzung" (MySQL -> MSSQL)?

Ein Thema von DeddyH · begonnen am 14. Dez 2017 · letzter Beitrag vom 18. Dez 2017
Antwort Antwort
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#1

Trigger-"Übersetzung" (MySQL -> MSSQL)?

  Alt 14. Dez 2017, 10:54
Datenbank: MSSQL • Version: 2008 • Zugriff über: egal
Ich habe in MySQL einen BEFORE UPDATE-Trigger geschrieben und versuche nun, diesen auch in MSSQL einzusetzen. Leider ist das nicht so einfach wie erhofft, daher bitte ich um Unterstützung durch einen MSSQL-Experten. Kurz zur Logik: es gibt ein Feld "uid", das durch ein Datenbank-Update zunächst NULL ist. Bei künftigen Updates soll dann Folgendes geschehen:
- Feld ist nicht NULL? Alten Wert behalten, ggf. neuen verwerfen
- Feld ist NULL, und es wurde ein Wert übergeben? Dann diesen übernehmen
- Feld ist NULL, kein Wert übergeben? Dann einen automatisch ermittelten schreiben

In MySQL sieht das bei mir so aus:
SQL-Code:
CREATE TRIGGER `Tabelle_KEEP_UID` BEFORE UPDATE ON Tabelle FOR EACH ROW
BEGIN
  DECLARE uidval varchar(36);
  IF (OLD.uid IS NOT NULL) THEN
    SET uidval = OLD.uid;
  ELSE
    IF (NEW.uid IS NOT NULL) THEN
      SET uidval = NEW.uid;
    ELSE
      SET uidval = lower(UUID());
    END IF;
  END IF;
  SET NEW.uid = uidval;
END
NEW und OLD gibt es in dieser Form bei MS nicht, da muss man wohl auf die "inserted"- bzw. "deleted"-Tabellen zugreifen. Leider scheitern alle meine bisherigen Versuche entweder an der Syntax oder der Logik oder beidem. Kann mir jemand helfen?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Trigger-"Übersetzung" (MySQL -> MSSQL)?

  Alt 14. Dez 2017, 11:25
Wenn ich die Doku richtig verstehe, befinden sich die alten Werte in deleted und die neuen in inserted

SQL-Code:
CREATE TRIGGER `Tabelle_KEEP_UID` BEFORE UPDATE ON Tabelle FOR EACH ROW
BEGIN
  DECLARE
    @uidval varchar(36);
    @uidval2 varchar(36);
    @ID ...

  select @uidval = deleted.uid from deleted;
  select @id = inserted.id, @uidval2 = inserted.uid from inserted;
  
  if (@uidval is null) then
    set @uidval = uidval2;
  end if

  if (@uidval is null) then
    set @uidval = lower(UUID());
  end if

  update Tabelle set uid = @uidval where ID = @ID;
END
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Trigger-"Übersetzung" (MySQL -> MSSQL)?

  Alt 14. Dez 2017, 11:31
Das erscheint schlüssig, probiere ich nach der Mittagspause gleich aus. Danke Dir
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.540 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Trigger-"Übersetzung" (MySQL -> MSSQL)?

  Alt 18. Dez 2017, 13:54
Nur zur Info: so funktioniert es endlich wie gewünscht (ist jetzt so etwas wie AFTER UPDATE FOR EACH ROW).
SQL-Code:
CREATE TRIGGER Tabelle_KEEP_UID ON Tabelle
FOR UPDATE AS
  DECLARE trg_cur CURSOR FOR
    SELECT ID, uid FROM deleted;

  DECLARE @ID integer;
  DECLARE @uidval varchar(36);
  DECLARE @uidval2 varchar(36);

  OPEN trg_cur;

  FETCH NEXT FROM trg_cur INTO @ID, @uidval;
  WHILE @@FETCH_STATUS = 0
  begin
    SELECT @uidval2 = uid FROM inserted WHERE ID = @ID;
   if (@uidval is null)
      set @uidval = @uidval2;
    if (@uidval is null)
      set @uidval = lower(newid());
    update Tabelle set uid = @uidval where ID = @ID;

    FETCH NEXT FROM trg_cur INTO @ID, @uidval;
  end;

  CLOSE trg_cur;
  DEALLOCATE trg_cur;
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  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 15:40 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