我是靠谱客的博主 追寻大地,最近开发中收集的这篇文章主要介绍SQL 关于插入数据是否正确的多表比较方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

触发器——实现数据的正确插入

触发器里面涉及到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 关于插入数据是否正确的多表比较方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部