触发器——实现数据的正确插入
触发器里面涉及到deleted和inserted两个非常重要的临时表。
现在有三张表:student_info(学号(PK) 姓名 班级),grade(学号(FK),课程编号(FK),分数),curriculum(课程编号(PK),课程名称,学分)
编写一个触发器:实现对grade插入时判断其学号和课程编号是否有对应的人和课程,没有则插入失败。
写法一:
用 IN 简单明了
CREATE TRIGGER [dbo].[trig_ins]
ON [dbo].[grade]
AFTER INSERT
AS
BEGIN TRANSACTION
IF(SELECT 学号 FROM inserted ) NOT IN (SELECT 学号 FROM student_info)
BEGIN
PRINT '无此学生!'
ROLLBACK TRANSACTION
RETURN
END
IF(SELECT 课程编号 FROM inserted) NOT IN (SELECT 课程编号 FROM curriculum)
BEGIN
PRINT '无此课程!'
ROLLBACK TRANSACTION
RETURN
END
PRINT '插入数据成功'
--SELECT 学号,课程编号,分数 FROM inserted 查询成功显示插入的数据
COMMIT TRANSACTION
写法二:
利用内连接(INNER JOIN)来判断
CREATE TRIGGER trig_ins
ON grade
AFTER INSERT
AS
BEGIN TRANSACTION
IF (SELECT COUNT(sid.学号) FROM (SELECT inserted.学号 FROM student_info INNER JOIN inserted
ON student_info.学号=inserted.学号) sid ) = 0
BEGIN
PRINT '无此学生'
ROLLBACK
RETURN
END
ELSE IF (SELECT COUNT(cid.课程编号) FROM (SELECT inserted.课程编号 FROM curriculum INNER JOIN inserted
ON curriculum.课程编号=inserted.课程编号) cid ) = 0
BEGIN
PRINT '无此课程'
ROLLBACK
RETURN
END
PRINT '插入数据成功'
--SELECT 学号,课程编号,分数 FROM inserted 查询成功显示插入的数据
COMMIT TRANSACTION