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 孩子16岁祝福语简短
13 怎么说祝福语简短
14 简短大气的狗年祝福语
15 生日祝福语 简短独特高考
16 孙女结婚姥姥祝福语简短
17 周日徒步祝福语大全简短
18 月子小孩祝福语大全简短