zoukankan      html  css  js  c++  java
  • TRIGGERS :Cannot use text, ntext, or image columns in the 'inserted' and ' deleted' tables.

    我本想利用SQL Server的Trigger来保存被删除的数据:

    create TRIGGER [mytable_delete_backup]
       ON  [dbo].[mytable]
       AFTER delete
    AS
    BEGIN
        -- SET NOCOUNT ON added to prevent extra result sets from
        -- interfering with SELECT statements.
        SET NOCOUNT ON;

        insert into mytable_bak select * from deleted

    END

    很不幸, 其中一个表里有NText 列, 结果遇到了标题的错误, 赶紧google一下, 没有什么好的解决方案,只能从比的地方下手, 而且有的人说trigger在多行处理上不稳定, 于是我就寻找在其他方法, 起初想用先用 insert .. select 方法,再delete, 但我的数据库上千万条数据, 这样做显然效率太低了。 最后想到用 delete output 方法:

    DELETE FROM table1 OUTPUT DELETED.* INTO table2 WHERE id in ( 2, 3)

    不过 output 有个小问题, 那就是 id 在table 1 中是identify (自增列)   在导入的表table2 中 必须将id 设为非自增的, 否则会报错。

  • 相关阅读:
    memcache 应用场景
    如何写接口文档(登录)
    PHP常见错误级别及错误码
    ex33 while 循环
    ex32 循环和列表
    ex31--作出决定
    ex29-30 if,elif and else.
    ex28 布尔表达式练习
    ex25 更多更多的实践
    ex21 函数可以返回某些东西
  • 原文地址:https://www.cnblogs.com/skyfei/p/1342977.html
Copyright © 2011-2022 走看看