Einzelnen Beitrag anzeigen

Benutzerbild von haentschman
haentschman

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

AW: FireDAC NO_SQL_DATA error

  Alt 8. Jun 2021, 07:27
Moin...
Zitat:
Wenn man Trigger macht, die auf Updates einer Tabelle reagieren und als (re)Aktion im Trigger ein Update auf die gleiche Tabelle macht, ist das nicht endlose Rekursion?
Der Trigger ist in Table Complete vorhanden und aktualisiert ausschließlich Table _Events
Code:
create table _Events
(
  ID int IDENTITY(1,1) NOT NULL,
  EventType int NOT NULL,
  EventName nvarchar(30) NOT NULL,
  EventCurrentGUID uniqueidentifier NOT NULL,
  CONSTRAINT Events_pk PRIMARY KEY CLUSTERED (ID ASC)
)
create index ixEventType on _Events (EventType)
GO

/* Events */
insert into _Events (EventType, EventName, EventCurrentGUID) values (0, 'Complete', NEWID())
GO

/* Trigger*/
create trigger TR_Complete on Complete for insert, update, delete as
begin
  update _Events set EventCurrentGUID = NEWID() where EventType = 0
end
GO
Zitat:
Interessante Ergebnisse im unteren Drittel
..was meinst du? Der doppelte EventType? Der ist immer eindeutig. Da aber alle Events manuell von mir manuell eingetragen werden, habe ich auf eine Prüfung verzichtet.


UPDATE:
1. SP erstellt
Code:
create procedure SP_EventsUpdate @EventType int
as
begin
  set NOCOUNT ON;
  update _Events set EventCurrentGUID = NEWID() where EventType = @EventType
end
GO
2. Trigger auf SP umgestellt
Code:
create trigger TR_Complete on Complete for insert, update, delete as
begin
  exec SP_EventsUpdate @EventType = 0
end
GO
PS: Das NOCOUNT ON im Trigger galt nur für diesen. Alle Anderen haben den Fehler geschmissen. Da war eine SP besser...

Geändert von haentschman ( 8. Jun 2021 um 08:33 Uhr)
  Mit Zitat antworten Zitat