如何使以下触发器支持批量更新、删除操作?

chc124 2010-05-15 11:24:07

ALTER TRIGGER [dbo].[tri_stu_aidu]
ON [dbo].[Student] AFTER INSERT,UPDATE,DELETE
AS
BEGIN
DECLARE @StuID char(10)
--INSERT操作
IF EXISTS(SELECT * FROM inserted) AND NOT EXISTS(SELECT * FROM deleted)
BEGIN
SELECT @StuID=StuID FROM inserted
INSERT INTO [dbo].[Account] VALUES(@StuID,@StuID,0)
END
--DELETE操作
ELSE IF NOT EXISTS(SELECT * FROM inserted) AND EXISTS(SELECT * FROM deleted)
DELETE FROM [dbo].[Account] WHERE [UserName]=(SELECT StuID FROM deleted)
--UPDATE操作
ELSE
UPDATE [dbo].[Account] SET [UserName]=(SELECT StuID FROM inserted)
WHERE [UserName]=(SELECT StuID FROM deleted)
END




这个触发器不支持Student表的批量更新和删除操作。

这个触发器的用意是:

每插入一个Student记录,都相应插入一个Account记录,使UserName和Password字段都等于[Student].[StuID]
Student表中的某条或某几条记录的StuID字段若更新,则更新Account表中对应的UserName字段。
若删除Student表中的一个记录,则删除对应的Account表中的记录。
...全文
177 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
chc124 2010-05-15
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 htl258 的回复:]
像这类的操作,最好做一下外键级联。
[/Quote]

主要是Account表中还有其他的非Student的账号。
我用Account表不仅存储学生的账号,还存储了老师的账号。
htl258_Tony 2010-05-15
  • 打赏
  • 举报
回复
像这类的操作,最好做一下外键级联。
htl258_Tony 2010-05-15
  • 打赏
  • 举报
回复
ALTER TRIGGER [dbo].[tri_stu_aidu]
ON [dbo].[Student]
AFTER INSERT,UPDATE,DELETE
AS
BEGIN
--INSERT操作
IF NOT EXISTS(SELECT * FROM deleted)
BEGIN
INSERT INTO [dbo].[Account]
SELECT StuID,StuID,0 FROM inserted
END
--DELETE操作
ELSE IF NOT EXISTS(SELECT * FROM inserted)
DELETE [dbo].[Account]
WHERE EXISTS (SELECT 1 FROM deleted WHERE [Account].[UserName]=StuID)
--UPDATE操作
ELSE
UPDATE A SET
A.[UserName]=C.StuID
FROM [dbo].[Account] A
JOIN (SELECT RN=ROW_NUMBER()OVER(ORDER BY GETDATE()),* FROM DELETED) B
ON A.[UserName]=B.StuID
JOIN (SELECT RN=ROW_NUMBER()OVER(ORDER BY GETDATE()),* FROM INSERTED) C
ON B.RN=C.RN
END

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧