Microsoft SQL Server 将数据移到表中(假设唯一键方法)

示例

移动数据,请先将其插入目标中,然后删除从源表中插入的所有内容。这不是正常的SQL操作,但可能会有所启发

您插入了什么?通常,在数据库中,您需要有一个或多个可用于唯一标识行的列,因此我们将假定并加以利用。

该语句选择一些行

SELECT Key1, Key2, Column3, Column4 FROM MyTable;

首先,将它们插入目标表:

INSERT INTO TargetTable (Key1, Key2, Column3, Column4)
SELECT Key1, Key2, Column3, Column4 FROM MyTable;

现在假设两个表中的记录是独一无二的Key1,Key2我们可以用它来查找和出源表中删除数据

DELETE MyTable
WHERE EXISTS (
    SELECT * FROM TargetTable 
    WHERE TargetTable.Key1 = SourceTable.Key1
    AND TargetTable.Key2 = SourceTable.Key2
);

这只会正常工作,如果Key1,Key2两个表中唯一

最后,我们不希望这项工作完成一半。如果我们将其包装在事务中,则所有数据将被移动,或者什么都不会发生。这样可以确保我们不会在其中插入数据,然后发现自己无法从源中删除数据。

BEGIN TRAN;

INSERT INTO TargetTable (Key1, Key2, Column3, Column4)
SELECT Key1, Key2, Column3, Column4 FROM MyTable;


DELETE MyTable
WHERE EXISTS (
    SELECT * FROM TargetTable 
    WHERE TargetTable.Key1 = SourceTable.Key1
    AND TargetTable.Key2 = SourceTable.Key2
);

COMMIT TRAN;