inserted i,deleted d,学习成绩表 b i d b是别名

解决方案 »

  1.   

    update
    产生两个临时表
    INSERTED修改后的记录
    DELETED修改前的记录
    D。B是表的别名
    D代表deleted 
    B代表学习成绩表
      

  2.   

    inserted deleted (是在触发器中经常用到的)表示动作涉及到的数据集
      

  3.   

    update 学习成绩表
    set 姓名=i.姓名
    from inserted i,deleted d,学习成绩表 b
    where d.姓名=b.姓名
    and d.id=i.id==>>
    ---这个没用别名:update 学习成绩表
    set 姓名=inserted.姓名
    from inserted,deleted
    where deleted.姓名=学习成绩表.姓名
    and deleted.id=inserted.id
    ==>update 学习成绩表set 姓名=别名1.姓名 <<=====这里呀!from inserted 别名1, <<=====这里deleted 别名2,学习成绩表 别名3
    where 别名2.姓名=别名3.姓名
    and 别名2.id=别名1.id
      

  4.   

    关于inserted 和 deleted :
    create table 表 (a int)
    go
    insert 表 values (1)
    go
    CREATE TRIGGER 名 ON 表
    FOR UPDATE
    AS
    select a 更新前被删除的数据 from deleted
    select a 更新后被插入的数据 from inserted
    go
    ------------测试:
    update 表 set a=3
      

  5.   

    使用 inserted 和 deleted 表
    触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。Microsoft&reg; SQL Server&#8482; 2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。inserted 和 deleted 表主要用于触发器中: 扩展表间引用完整性。
    在以视图为基础的基表中插入或更新数据。
    检查错误并基于错误采取行动。
    找到数据修改前后表状态的差异,并基于此差异采取行动。 
    Deleted 表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE 语句时,行从触发器表中删除,并传输到 deleted 表中。Deleted 表和触发器表通常没有相同的行。Inserted 表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。Inserted 表中的行是触发器表中新行的副本。更新事务类似于在删除之后执行插入;首先旧行被复制到 deleted 表中,然后新行被复制到触发器表和 inserted 表中。在设置触发器条件时,应当为引发触发器的操作恰当使用 inserted 和 deleted 表。虽然在测试 INSERT 时引用 deleted 表或在测试 DELETE 时引用 inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。说明  如果触发器操作取决于一个数据修改所影响的行数,应该为多行数据修改(基于 SELECT 语句的 INSERT、DELETE 或 UPDATE)使用测试(如检查 @@ROWCOUNT),然后采取相应的对策。
    SQL Server&#8482; 2000 不允许 AFTER 触发器引用 inserted 和 deleted 表中的 text、ntext 或 image 列;然而,允许 INSTEAD OF 触发器引用这些列。有关更多信息,请参见 CREATE TRIGGER。
      

  6.   

    使用 inserted 和 deleted 表
    触发器语句中使用了两种特殊的表:deleted 表和 inserted 表。Microsoft&reg; SQL Server&#8482; 2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。inserted 和 deleted 表主要用于触发器中: 扩展表间引用完整性。
    在以视图为基础的基表中插入或更新数据。
    检查错误并基于错误采取行动。
    找到数据修改前后表状态的差异,并基于此差异采取行动。 
    Deleted 表用于存储 DELETE 和 UPDATE 语句所影响的行的复本。在执行 DELETE 或 UPDATE 语句时,行从触发器表中删除,并传输到 deleted 表中。Deleted 表和触发器表通常没有相同的行。Inserted 表用于存储 INSERT 和 UPDATE 语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到 inserted 表和触发器表中。Inserted 表中的行是触发器表中新行的副本。更新事务类似于在删除之后执行插入;首先旧行被复制到 deleted 表中,然后新行被复制到触发器表和 inserted 表中。在设置触发器条件时,应当为引发触发器的操作恰当使用 inserted 和 deleted 表。虽然在测试 INSERT 时引用 deleted 表或在测试 DELETE 时引用 inserted 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。