使用SELECT查询加速UPDATE

时间:2009-08-20 00:33:21

标签: sql-server sql-server-2005 optimization

我有两张桌子:

  • 表1有Episode and Code,Episode as distinct。
  • 表2有剧集和代码,但剧集并不明显(表格中的其他字段,与任务无关,使每一行都是唯一的。)

我希望将每个剧集的表1的代码复制到表2。执行此操作的当前代码如下:

UPDATE Table2
SET Table2.Code = (SELECT TOP 1 Code FROM Table1 WHERE Episode = Table2.Episode)

这需要数小时和数小时。 (我不确切地知道多少小时,因为我在大约20小时的时候取消了它。)他们大桌子,但肯定有更快的方法吗?

3 个答案:

答案 0 :(得分:5)

我没有一个方便的SQL Server,我不完全确定,但我似乎记得有一个类似下面的语法应该可以加快速度。

 UPDATE Table2 SET Table2.Code = Table1.Code FROM Table1 
 WHERE Table1.Episode = Table2.Episode

答案 1 :(得分:1)

两张桌子上的“代码”和“剧集”列都有索引吗?那些肯定会有助于加快速度!

马克

答案 2 :(得分:1)

您可以将UPDATE与此类联接一起使用。请注意,您必须指定FROM

UPDATE MyTable
SET MyColVal = O.NewVal
FROM MyTable T
INNER JOIN MyOtherTable O ON T.Id=O.Id
WHERE ...

http://doc.ddart.net/mssql/sql70/ua-uz_3.htm