在SQL Server中,可以使用insert将行插入到表中。。SELECT语句:
INSERT INTO Table (col1, col2, col3)
SELECT col1, col2, col3
FROM other_table
WHERE sql = 'cool'
是否也可以使用SELECT更新表?我有一个包含这些值的临时表,并希望使用这些值更新另一个表。也许是这样的:
UPDATE Table SET col1, col2
SELECT col1, col2
FROM other_table
WHERE sql = 'cool'
WHERE Table.id = other_table.id
SQL数据库中使用INNER JOIN从SELECT进行UPDATE
由于这篇文章的回复太多了,投票最多,我想我也会在这里提供我的建议。虽然这个问题很有趣,但我在许多论坛网站上看到过,并使用INNER JOIN和截屏制作了一个解决方案。
首先,我创建了一个名为schoolold的表,并插入了一些与列名相关的记录并执行它。
然后我执行SELECT命令来查看插入的记录。
然后我创建了一个名为schoolnew的新表,并对其执行了类似的上述操作。
然后,为了查看其中插入的记录,我执行SELECT命令。
现在,我想对第三行和第四行进行一些更改,为了完成此操作,我使用INNER JOIN执行UPDATE命令。
要查看更改,我执行SELECT命令。
通过使用INNER JOIN with UPDATE语句,您可以看到表schoolold的第三和第四记录如何容易地替换为表schoolnew。
UPDATE TQ
SET TQ.IsProcessed = 1, TQ.TextName = 'bla bla bla'
FROM TableQueue TQ
INNER JOIN TableComment TC ON TC.ID = TQ.TCID
WHERE TQ.IsProcessed = 0
要确保正在更新所需内容,请先选择
SELECT TQ.IsProcessed, 1 AS NewValue1, TQ.TextName, 'bla bla bla' AS NewValue2
FROM TableQueue TQ
INNER JOIN TableComment TC ON TC.ID = TQ.TCID
WHERE TQ.IsProcessed = 0
SQL数据库中使用INNER JOIN从SELECT进行UPDATE
由于这篇文章的回复太多了,投票最多,我想我也会在这里提供我的建议。虽然这个问题很有趣,但我在许多论坛网站上看到过,并使用INNER JOIN和截屏制作了一个解决方案。
首先,我创建了一个名为schoolold的表,并插入了一些与列名相关的记录并执行它。
然后我执行SELECT命令来查看插入的记录。
然后我创建了一个名为schoolnew的新表,并对其执行了类似的上述操作。
然后,为了查看其中插入的记录,我执行SELECT命令。
现在,我想对第三行和第四行进行一些更改,为了完成此操作,我使用INNER JOIN执行UPDATE命令。
要查看更改,我执行SELECT命令。
通过使用INNER JOIN with UPDATE语句,您可以看到表schoolold的第三和第四记录如何容易地替换为表schoolnew。
在接受的答案中,在以下内容之后:
SET
Table_A.col1 = Table_B.col1,
Table_A.col2 = Table_B.col2
我想补充一句:
OUTPUT deleted.*, inserted.*
我通常做的是将所有内容放入回滚事务中,并使用“OUTPUT”:这样我就可以看到即将发生的一切。当我对所看到的感到满意时,我将ROLLBACK更改为COMMIT。
我通常需要记录我所做的事情,所以我在运行回滚查询时使用“results to Text”选项,并保存脚本和OUTPUT的结果。(当然,如果我更改了太多行,这是不可行的)