我有两张桌子:
“distinct.
我想把表1的代码拷贝到表2中。执行此操作的当前代码如下:
UPDATE Table2
SET Table2.Code = (SELECT TOP 1 Code FROM Table1 WHERE Episode = Table2.Episode)这要花上好几个小时。(我不知道确切的时间是多少小时,因为我在20小时左右取消了它。)他们是大桌子,但肯定有更快的方法吗?
发布于 2009-08-20 00:41:43
我手头没有SQL Server,我也不完全确定,但我似乎还记得有一种语法,如下面所示,可能会加快速度。
UPDATE Table2 SET Table2.Code = Table1.Code FROM Table1
WHERE Table1.Episode = Table2.Episode发布于 2009-08-20 05:36:24
两表中的“代码”栏和“史诗”栏是否有任何索引?这些肯定会大大加快速度!
Marc
发布于 2009-08-21 08:12:53
您可以在这样的联接中使用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
https://stackoverflow.com/questions/1303367
复制相似问题