update更新语句优化请教

qq_22264283 2025-08-19 19:26:58

有以下更新SQL语句:
其中表StuKskmStructure中有40万条数据左右;IN子句查询出来的数据,最多300条;现在发现2个问题:
一是更新速度相对比较慢,能不能优化?
二是发现如果去掉更新get4Time=getdate(),发现速度会提升2倍左右,这是怎么回事呢?有没有办法优化呢?

StuKskmStructure表中建立了papernumber和stth的聚集索引;ZmtkmTeacher设置了userid和task的聚集索引。用的是SQL SERVER 2014。

谢谢大家!

UPDATE StuKskmStructure SET UserId4=?,get4Time=getdate()
WHERE PaperNumber=? and STTH IN
(SELECT STTH FROM ZmtkmTeacher WHERE UserId=? AND Task=4)
...全文
成就一亿技术人!
拼手气红包 10.00元
748 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
吉普赛的歌 版主 7天前
  • 打赏
  • 举报
回复 1

来晚了,没有红包,【哭】
试下:

---------------- 解决方案 1
UPDATE s
SET s.UserId4 = ?, 
    s.get4Time = GETDATE()
FROM StuKskmStructure s
INNER JOIN ZmtkmTeacher z 
    ON s.STTH = z.STTH
WHERE s.PaperNumber = ?
  AND z.UserId = ?
  AND z.Task = 4;

---------------- 解决方案 2
-- 先缓存匹配的 STTH
SELECT STTH 
INTO #TempSTTH
FROM ZmtkmTeacher 
WHERE UserId = ? AND Task = 4;

-- 创建索引(重要!)
CREATE CLUSTERED INDEX IX ON #TempSTTH (STTH);

-- 使用 JOIN 更新
UPDATE s
SET s.UserId4 = ?, 
    s.get4Time = GETDATE()
FROM StuKskmStructure s
INNER JOIN #TempSTTH t ON s.STTH = t.STTH
WHERE s.PaperNumber = ?;

-- 清理
DROP TABLE #TempSTTH;

34,871

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧