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,怎么办?
展开
 我来答
jiumujiang
2009-11-17 · TA获得超过400个赞
知道答主
回答量:171
采纳率:0%
帮助的人:0
展开全部
下面是在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取消掉就行了
a5202003
2009-11-18 · TA获得超过2248个赞
知道大有可为答主
回答量:1885
采纳率:75%
帮助的人:579万
展开全部
没办法,要么去掉外键,要么不用触发器,二者选其一。

投机一点的办法就是,删除的时候,在触发器里加上去掉外键的代码,然后级联删除,删除之后再创建外键关联。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
粗香蕉
2009-11-13 · TA获得超过518个赞
知道小有建树答主
回答量:213
采纳率:0%
帮助的人:150万
展开全部
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)

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

不知满意否>

如果一定要用 也可以留言给我 继续作答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式