向高手求救:这道‘触发器’怎么设计?~~~~~~~~~~~UP者有分!

XXSingle 2003-10-16 06:09:36
表A:ID,Name
表B:ID,Num,Value
------------
表A与表B是一对多关系;
当表A的ID改变时,表B的ID也会自动跟着改变,
求助:这个触发器怎么设计?
...全文
38 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
welyngj 2003-10-17
  • 打赏
  • 举报
回复
使用 inserted 和 deleted 表
触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。Microsoft® SQL Server™ 2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。

inserted 和 deleted 表主要用于触发器中:

扩展表间引用完整性。


在以视图为基础的基表中插入或更新数据。


检查错误并基于错误采取行动。


找到数据修改前后表状态的差异,并基于此差异采取行动。
Deleted 表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE 语句时,行从触发器表中删除,并传输到 deleted 表中。Deleted 表和触发器表通常没有相同的行。

Inserted 表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。Inserted 表中的行是触发器表中新行的副本。

更新事务类似于在删除之后执行插入;首先旧行被复制到 deleted 表中,然后新行被复制到触发器表和 inserted 表中。

在设置触发器条件时,应当为引发触发器的操作恰当使用 inserted 和 deleted 表。虽然在测试 INSERT 时引用 deleted 表或在测试 DELETE 时引用 inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。

perfwell 2003-10-17
  • 打赏
  • 举报
回复
create trigger tri1 on 表A
for update
as
if update(ID)
begin
update 表B set ID=(select id from inserted) from deleted where 表B.id=deleted.id
end

inserted,deleted代表什么意思?是系统为了回滚写在系统的临时表,
XXSingle 2003-10-17
  • 打赏
  • 举报
回复
有点不明白:inserted,deleted代表什么意思?

XXSingle 2003-10-17
  • 打赏
  • 举报
回复
多谢sdhdy(大江东去...) 和pengdali(大力 V3.0)
两位高手啦...........
pengdali 2003-10-16
  • 打赏
  • 举报
回复
企业管理器--右键表--设计表--任意字段处按右键--关系--新建--设置与其他表的关联(即那些表的字段与本表的字段有关系,要被自动更新)--设置好后,选中"对 INSERT 和 UPDATE 强制关系"--并同时选中"级联更新相关的字段",如果要级联删除,再选中"级联删除相关的记录"--最后确定就可以了
pengdali 2003-10-16
  • 打赏
  • 举报
回复
但这些都不支持更新多条
pengdali 2003-10-16
  • 打赏
  • 举报
回复
create trigger tri1 on 表A
for update
as
if update(ID)
begin
update 表B set ID=(select id from inserted) where id=(select id from deleted)
end
sdhdy 2003-10-16
  • 打赏
  • 举报
回复
create trigger tri1 on 表A
for update
as
if update(ID)
begin
update 表B set ID=(select id from inserted) from deleted where 表B.id=deleted.id
end

22,206

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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