sql2000 如何用触发器实现级联删除

来源:百度知道 编辑:UC知道 时间:2024/05/15 12:09:16
例如:我有3张表
user(user_id)
topic(topic_id)
UT(UT_id,user_id,topic_id,foreign key(user_id) references user(user_id),foreign key(topic_id) references topic(topic_id))
UT表中的user_id、topic_id是外键,现在我想当删除user表中的数据时,UT表中
相应的数据也被删除,同时的,当我想删除topic表中的数据时,UT表中
相应的数据也被删除.我不想用on delete cascade级联删除,因为会出现循环报错,我想用触发器实现on delete cascade级联删除功能,如何实现?
上面写错了,实际上是有4个表
user(user_id)
topic(topic_id)
topic_verify(topic_id,foreign key(topic_id) references topic(topic_id))
UT(UT_id,user_id,topic_id,foreign key(user_id) references user(user_id),foreign key(topic_id) references topic_verify(topic_id))

jiumujiang你的方法我试了,但我的user表中的user_id是其他表的外键,并设定了级联删除,所以我创建不了触发器,出现错误:因为该表的 FOREIGN KEY 带有级联 DELETE 或 UPDATE,怎么办?

下面是在user表上建立触发器的语句,在topic上建触发器的语句类似

CREATE TRIGGER deleteuser ON [dbo].[user]
INSTEAD OF DELETE
AS
DECLARE @id int; --把数据类型改成与user_id一致
SELECT @id=user_id from deleted;
DELETE FROM UT
WHERE user_id=@id;
DELETE FROM user
WHERE user_id=@id;

你把级联 DELETE 或 UPDATE取消掉就行了

delete user where user_id in (select user_id from UT where 1=1)

delete topic where topic_id in (select topic_id from UT where 1=1)

无须触发器. 直接用子删除语句即可实现.

不知满意否>

如果一定要用 也可以留言给我 继续作答

没办法,要么去掉外键,要么不用触发器,二者选其一。

投机一点的办法就是,删除的时候,在触发器里加上去掉外键的代码,然后级联删除,删除之后再创建外键关联。。。