我有一个表“game.FileAttachments”,它有一个stream_id 列,该列链接到文件表“game.Attachments”的stream_id 列。我在 File 表上创建了一个 Update 触发器,以更新链接表上的 stream_id;原因是,当 File 表中的文件被修改时,stream_id 会发生变化。这是我的触发器;请帮忙!
CREATE TRIGGER game.tr_Update_Attachments
ON game.Attachments
AFTER UPDATE
AS
BEGIN
SET NOCOUNT ON;
IF ( UPDATE(stream_id) )
BEGIN
UPDATE game.FileAttachments
SET stream_id = i.stream_id
FROM inserted i
WHERE game.FileAttachments.stream_id IN
(
SELECT d.stream_id
FROM deleted d INNER JOIN
game.FileAttachments f ON f.stream_id = d.stream_id
)
END
END
也试过这个:
IF ( UPDATE(stream_id) )
BEGIN
UPDATE game.FileAttachments
SET stream_id = i.stream_id
FROM inserted i INNER JOIN
deleted d ON 1 = 1 INNER JOIN
game.FileAttachments f ON f.stream_id = d.stream_id
END
但这也行不通。
好的,我创建了一个删除触发器来测试一个理论;与我正在修改的文件关联的 FileTable 记录没有更新,而是被删除,并创建了一个全新的记录。好吧,事实证明,对于 Word 女士来说,这是真的。但是,创建了一个纯文本文件,我可以根据需要进行多次更新,并且 stream_id 永远不会改变。因此,Microsoft Word,该应用程序似乎克隆了原始文档,给它一个临时名称,然后,当用户选择保存它时,原始文档被简单地删除,并且克隆重命名为与原始文档相同。那个字节!