|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Junior Member
Iscritto dal: Jan 2010
Città: Bologna
Messaggi: 3
|
[SQL] Problema creazione trigger
Salve a tutti, vi scrivo per chiedere aiuto in merito alla creazione di un trigger in SQL Server. La tabella in questione è la seguente:
Codice:
CREATE TABLE edizione ( id_edizione int PRIMARY KEY, data_inizio date, data_fine date, corso nchar[5] REFERENCES corso(codice_corso) ) Ho provato a scriverlo (allego il codice a fine post) ma per qualche ragione che non riesco a comprendere esso impedisce l'inserimento di qualsiasi nuova edizione, anche se non rientra nei parametri specificati sopra. Prima prova Codice:
CREATE TRIGGER TR_date ON dbo.edizione AFTER INSERT, UPDATE AS DECLARE @data_inizio date, @data_fine date SELECT @data_inizio = inserted.data_inizio, @data_fine = edizione.data_fine FROM edizione INNER JOIN inserted WHERE edizione.corso = inserted.corso IF @data_fine >= @data_inizio BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- Insert statements for trigger here ROLLBACK TRAN PRINT 'Errore: una edizione deve iniziare dopo la conclusione dell altra' END GO Codice:
CREATE TRIGGER [dbo].[TR_date] ON [dbo].[edizione] AFTER INSERT, UPDATE AS DECLARE @data_inizio date, @data_fine date, @corso nchar(5) SET @data_inizio = (SELECT inserted.[data_inizio] FROM inserted) SET @corso = (SELECT inserted.[corso] FROM inserted) SET @data_fine = (SELECT edizione.[data_fine] FROM edizione WHERE corso = @corso) IF @data_fine >= @data_inizio BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- Insert statements for trigger here ROLLBACK TRAN PRINT 'Errore: una edizione deve iniziare dopo la conclusione dell altra' END |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Non conosco l'engine SQL che stai usando, per cui vado a sensazione:
- non stai usando NOW.data_inizio nel confronto - devi recuperare MAX(edizione.data_fine) e usarlo nel confronto - il confronto devi farlo con > anziché >=
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Ti consiglio di non mettere mai statement COMMIT o ROLLBACK dentro alcun trigger. Il controllo della transazione lascialo fare all'esterno. Ci sono problemi che potresti non vedere, come es. transazioni annidate.
E per questo caso ti consiglio di fare trigger "Instead of", nei quali a seconda della condizione piloterai o meno la vera Insert / Update.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
![]() |
![]() |
![]() |
#4 | |
Junior Member
Iscritto dal: Jan 2010
Città: Bologna
Messaggi: 3
|
Quote:
|
|
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Sisi', ma per quelli mi sembrava che il consigli di cdimauro fossero corretti.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
![]() |
![]() |
![]() |
#6 |
Junior Member
Iscritto dal: Jan 2010
Città: Bologna
Messaggi: 3
|
Ho modificato così il codice:
Codice:
CREATE TRIGGER [dbo].[TR_date] ON [dbo].[edizione] INSTEAD OF INSERT AS DECLARE @data_inizio date, @data_fine date, @corso nchar(5) SET @data_inizio = (SELECT inserted.[data_inizio] FROM inserted) SET @corso = (SELECT inserted.[corso] FROM inserted) SET @data_fine = (SELECT MAX(edizione.[data_fine]) FROM edizione WHERE corso = @corso) IF @data_fine > @data_inizio BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- Insert statements for trigger here INSERT INTO edizione SELECT data_inizio, data_fine, corso FROM inserted END |
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Io per intanto vedo questo
Quote:
Codice:
IF @data_fine > @data_inizio "inserted" e' quindi un insieme di record, non uno solo. Devi quindi operare per SET, facendo magari un loop sui vari dati in ingresso (poi magari toglierai questi loop, dato che e ' possibile torglierli quasi sempre e forse sempre). e per ciascuno dei record dovrai decidere se inserirlo oppure no.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 19:06.