gpt4 book ai didi

sql - 使用多列执行一次更新比执行多次更新更有效吗

转载 作者:行者123 更新时间:2023-12-04 14:21:08 25 4
gpt4 key购买 nike

你觉得怎样更好。每次更新表的所有列,即使并非所有值都发生更改,或者仅更新更改的列并进行多次更新。这个想法是,而不是立即更新每一个更改,等待一些更改然后更新所有列,但我不想实现确定哪些列已更改的逻辑。

UPDATE myTable 
SET col1 = newVal1,
col2 = oldVal2,
col3 = newVal3,
...
WHERE x = y

对比
UPDATE myTable SET col1 = newVal1 WHERE x = y
UPDATE myTable SET col3 = newVal3 WHERE x = y
...

我正在使用 SQL Server 2014 Express。

最佳答案

第一个查询会执行得更好,因为它只需要在表上执行单个 scan/seek。但是在第一个查询中,您可以更新具有要更新的新值的列:

UPDATE myTable 
SET col1 = newVal1,
col3 = newVal3,
...
where x = y

但是第二个查询必须为每个 scan/seek 对表进行 Update,这将比第一个查询花费更多的时间。

关于sql - 使用多列执行一次更新比执行多次更新更有效吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40949157/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com