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;
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短