SQL 关于插入数据是否正确的多表比较方法

本文介绍如何使用SQL触发器确保在插入数据到grade表时,学号和课程编号必须存在于student_info和curriculum表中,从而维护数据的完整性。通过两种方法实现:一是使用IN语句检查,二是利用INNER JOIN进行判断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

触发器里面涉及到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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值