4

我有一个表“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,该应用程序似乎克隆了原始文档,给它一个临时名称,然后,当用户选择保存它时,原始文档被简单地删除,并且克隆重命名为与原始文档相同。那个字节!

4

1 回答 1

0

我认为你的触发器定义需要有这个:

CREATE TRIGGER game.tr_Update_Attachments
ON  game.Attachments
AFTER UPDATE, DELETE

如您所指:

SELECT d.stream_id
                FROM deleted d INNER JOIN 
                     game.FileAttachments f ON f.stream_id = d.stream_id

在您的 where 子句中...或者您错误地引用了此表并需要将“已删除”附件捕获到临时表中?

于 2014-08-29T13:35:32.580 回答