5

我知道标题可能看起来很奇怪,但这是我想做的:

  1. 我有很多记录的表。
  2. 我想获取其中一些记录并将它们插入到其他表中。像这样的东西:

    INSERT INTO TableNew SELECT * FROM TableOld WHERE ...

  3. 棘手的部分是我希望我插入的这些行也从原始表中删除。

有没有一种简单的方法可以做到这一点,因为我唯一想到的是使用临时表来保存选定的记录,然后将它们放在第二个表中并从第一个表中删除与它们匹配的行. 这是一个解决方案,但有这么多记录(超过 300 万条半),我正在寻找其他想法......

4

3 回答 3

14

在 2005+ 中使用OUTPUT这样的子句:

DELETE FROM TableOld 
OUTPUT DELETED.* INTO TableNew
WHERE YourCondition

它将在单个事务中执行,并同时完成或回滚

于 2012-01-23T07:51:42.317 回答
2

您可以使用insert ... output子句将复制行的 ID 存储在临时表中。然后您可以根据临时表从原始表中删除行。

declare @Table1 table (id int, name varchar(50))
declare @Table2 table (id int, name varchar(50))

insert @Table1 (id,name)
          select 1, 'Mitt'
union all select 2, 'Newt'
union all select 3, 'Rick'
union all select 4, 'Ron'


declare @copied table (id int)

insert  @Table2
        (id, name)
output  inserted.id 
into    @copied
select  id
,       name
from    @Table1
where   name <> 'Mitt'

delete  @Table1
where   id in 
        (
        select  id 
        from    @copied
        )
        
select  *
from    @Table1

Data Explorer 的工作示例。

于 2012-01-23T07:58:53.057 回答
0

你应该做这样的事情:

INSERT INTO "table1" ("column1", "column2", ...)
SELECT "column3", "column4", ...
FROM "table2" 
WHERE ...

DELETE FROM "table1"
WHERE ...
于 2012-01-23T07:51:25.810 回答