概述
触发器——实现数据的正确插入
触发器里面涉及到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
最后
以上就是追寻大地为你收集整理的SQL 关于插入数据是否正确的多表比较方法的全部内容,希望文章能够帮你解决SQL 关于插入数据是否正确的多表比较方法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复