
如何使用sql server快速批量更新数据
需要根据一些不同的条件更新不同的数据,需要运行一些循环语句,使用游标更新速度太慢,求问有没有更快一点的方法?补充具体事例:比如现在有一个表的表头是{状态,a,a1,b1,...
需要根据一些不同的条件更新不同的数据,需要运行一些循环语句,使用游标更新速度太慢,求问有没有更快一点的方法?
补充具体事例:
比如现在有一个表的表头是{状态,a,a1,b1,b2,b3……bn},现在要实现:if 状态= m set {b1=1, ...,ba = 1}; if 状态 = n set {b1 =1,..., ba1 = 1}
一共有400多万条数据,以前用游标做时每千条要耗时30秒左右,现在需要把时间压缩到每千条10秒左右
谢谢!
看到网上说可以添加索引提升速度,不知道我这种情况适不适合添加索引? 展开
补充具体事例:
比如现在有一个表的表头是{状态,a,a1,b1,b2,b3……bn},现在要实现:if 状态= m set {b1=1, ...,ba = 1}; if 状态 = n set {b1 =1,..., ba1 = 1}
一共有400多万条数据,以前用游标做时每千条要耗时30秒左右,现在需要把时间压缩到每千条10秒左右
谢谢!
看到网上说可以添加索引提升速度,不知道我这种情况适不适合添加索引? 展开
3个回答
展开全部
试试循环吧
declare @cnt int
select @cnt = count(1) from A
while(@cnt > 0)
begin
--更新
set @cnt = @cnt - 1
end
按照你补充的,你这个完全可以把几种状态的判断先做好,然后直接对满足条件的批量更新。
做个临时表放置标识字段跟状态,对满足某个状态的批量update。
索引可以优化查询,update跟delete这种操作反而会破坏索引。
展开全部
你都不说清楚情况,哪来的办法
追问
比如现在有一个表的表头是{状态,a,a1,b1,b2,b3……bn},现在要实现:if 状态= m set {b1=1, ...,ba = 1}; if 状态 = n set {b1 =1,..., ba1 = 1}
一共有400多万条数据,以前用游标做时每千条要耗时1分钟左右,现在需要把时间压缩到每千条10秒左右
谢谢!
追答
是不是状态不一样 要设置不同的列=1 ?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你这个为什么要用游标?循环下状态不就可以了!要看你状态有多少种了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询