sql2000 如何用触发器实现级联删除
例如:我有3张表user(user_id)topic(topic_id)UT(UT_id,user_id,topic_id,foreignkey(user_id)refe...
例如:我有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(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取消掉就行了
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)
无须触发器. 直接用子删除语句即可实现.
不知满意否>
如果一定要用 也可以留言给我 继续作答
delete topic where topic_id in (select topic_id from UT where 1=1)
无须触发器. 直接用子删除语句即可实现.
不知满意否>
如果一定要用 也可以留言给我 继续作答
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询