Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

UPDATE Trigger Problem bei SQL Server

Empfohlene Antworten

Veröffentlicht

Hallo,

ich möchte mit Hilfe von einem Trigger in eine Tabelle Daten speichern wenn in eine

Spalte von der Tabelle wo der Trigger eingelegt worden ist man wert null schreibt, und aber Früher einen wert da wahr.

So habe ich es versucht zu lösen,


CREATE TRIGGER [UPDATE_TEST] ON [dbo].[TEST]
FOR UPDATE
AS
insert into DeleteProtokol(lalala)
select lalala from inserted
where datumspalte is null

[/PHP]

leider funktioniert es nur bedingt dh. es werden werte auch gespeichert wenn das wert vorher auch null wahr.

  • Autor
Da müsstest du die deleted-Tabelle über deinen Primary Key dazujoinen und in der Tabelle halt abfragen, ob der Wert vorher not null war...

warum deleted-Tabelle und was mache wenn jemand erstmal den Datensatz

mit null werten neu einfügt ??

Naja, in der deleted-Tabelle stehen ja die Daten vor dem Update (der SQL-Server macht bei einem UPDATE ja nichts anderes als ein DELETE und danach ein INSERT) - also bekommst du damit heraus, ob in der Spalte vorher ein NOT NULL stand. Wenn du das ganze dann noch mit LEFT JOIN zusammensetzt, kannste auch herausfinden, wenn der Datensatz neu erstellt wurde - also in etwa so:



insert into DeleteProtokol (lalala)

select lalala from inserted i

  left outer join deleted d on (d.id = i.id)

where  i.datumspalte is null and d.datumspalte is not null

Vorausgesetzt, der Primary Key heißt ID - mit dem obigen Statement müsstest du dann alle Datensätze erwischen, die vorher schon in der DB waren, im Feld datumspalte einen Wert stehen hatten und jetzt dort NULL eingefügt werden soll.

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.