我正在研究触发器,有一个问题。
我正在创建一个触发器来改变时间复杂性。
在数据表weeklymeeting
中
|section_id| meeting type| days| timestart|timeend|class_id|
| 13 | Lecture | 5 | 01:00:00 |02:00:00|12 |
CCD_ 2和CCD_ 3的数据类型为TIME
我正在创建检查时间复杂的触发器
例如
如果用户使用类似的查询
INSERT INTO DBO.WeeklyMeetings VALUES (35, 1,1 ,'11:40:00','11:42:00', 42)
它应该插入数据
然而
INSERT INTO CSE132B.DBO.WeeklyMeetings VALUES (35, 1, 1, '12:30:00','01:30:00', 42)
则它必须返回错误消息,因为它是时间复杂的
因此,我创建了一个触发器来检查时间复合体。。但是诸如
ALTER TRIGGER [dbo].[check_section_time_complex] ON [dbo].[WeeklyMeetings]
FOR INSERT AS
IF EXISTS(select * from inserted as i INNER JOIN dbo.WeeklyMeetings as m ON (i.timestart BETWEEN m.timestart and m.timeend)
OR( i.timeend BETWEEN m.timestart and m.timeend ))
begin
RAISERROR ('Can not update data because section time is complexing with other section!!', 16,1);
rollback tran
end
然而,它并没有真正起作用。。。我真的不确定那个原因。。。。
有人知道这个触发器有问题吗?
感谢
如果您所说的"它不真正工作"是指它允许插入冲突的数据,然后引发错误,这是因为您指定了FOR INSERT
触发器,这意味着它在插入数据后发生。
如果您想阻止插入数据,则需要使用INSTEAD OF
触发器,该触发器发生在插入之前,如果有效,则在其中自己插入。
请参阅http://msdn.microsoft.com/en-us/library/ms189799.aspx用于触发器定义。
如果错误是其他原因,请更全面地描述它。