首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用SELECT查询加速更新

使用SELECT查询加速更新
EN

Stack Overflow用户
提问于 2009-08-20 00:33:20
回答 3查看 774关注 0票数 0

我有两张桌子:

“distinct.

  • Table 2”表1有“史诗”和“代码”,而“史诗2”有“史诗”和“代码”,但“史诗”没有区别(表中的其他字段,与任务无关,使每一行都是唯一的)。

我想把表1的代码拷贝到表2中。执行此操作的当前代码如下:

代码语言:javascript
复制
UPDATE Table2
SET Table2.Code = (SELECT TOP 1 Code FROM Table1 WHERE Episode = Table2.Episode)

这要花上好几个小时。(我不知道确切的时间是多少小时,因为我在20小时左右取消了它。)他们是大桌子,但肯定有更快的方法吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-08-20 00:41:43

我手头没有SQL Server,我也不完全确定,但我似乎还记得有一种语法,如下面所示,可能会加快速度。

代码语言:javascript
复制
 UPDATE Table2 SET Table2.Code = Table1.Code FROM Table1 
 WHERE Table1.Episode = Table2.Episode
票数 5
EN

Stack Overflow用户

发布于 2009-08-20 05:36:24

两表中的“代码”栏和“史诗”栏是否有任何索引?这些肯定会大大加快速度!

Marc

票数 1
EN

Stack Overflow用户

发布于 2009-08-21 08:12:53

您可以在这样的联接中使用UPDATE。注意,您必须指定FROM

代码语言:javascript
复制
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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1303367

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档