SQL触发器 例题

为student表创建后触发器,在插入数据后更新class表中的StudentNum列信息:

create trigger tri_Student on Class after update

as

       update Class set StudentNum=(select StudentNum from inserted)

为teacher表创建后触发器,在删除教师数据后同步删除schedule表中该教师的数据:

create trigger tri_Teacher on Schedule after delete

as

       delete from Schedule where TeacherID=(select TeacherID from deleted)

go

创建触发器depart_before_delete_trigger,当删除department表中的某个系信息前,首先删除该系的班级信息。并且测试触发器。

create trigger depart_before_delete_trigger on Department instead of delete

as

begin

       delete from Class where DepartmentID=(select DepartmentID from deleted)

end

go



select *from Department

select*from Class

delete from Department where DepartmentId='Dp02'

创建触发器course_before_insert_trigger, 限制学分只能在1~6之间并且测试触发器创建触发器

create trigger course_before_insert_trigger on Course after insert

as

begin

declare @credit int

select @credit=credit from Course where credit=(select credit from inserted)

if(@credit not between 1 and 6)

       begin

       rollback transaction

       print'输入失败请重新输入'

       end

end



insert into Course(CourseID,CourseName,BookNmae,[period],credit)

values('12344','wefj','svfdsd',60,5)

select *from Course

你可能感兴趣的:(SQL学习,sql,数据库,database)