如何使用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心竹
推荐于2016-02-17 · TA获得超过206个赞
知道小有建树答主
回答量:261
采纳率:0%
帮助的人:155万
展开全部

试试循环吧

declare @cnt int
select @cnt = count(1) from A
while(@cnt > 0)
begin
--更新
set @cnt = @cnt - 1
end

按照你补充的,你这个完全可以把几种状态的判断先做好,然后直接对满足条件的批量更新。
做个临时表放置标识字段跟状态,对满足某个状态的批量update。

 索引可以优化查询,update跟delete这种操作反而会破坏索引。

救救大汉江山吧
2014-10-23 · 超过61用户采纳过TA的回答
知道小有建树答主
回答量:222
采纳率:100%
帮助的人:102万
展开全部
你都不说清楚情况,哪来的办法
追问
比如现在有一个表的表头是{状态,a,a1,b1,b2,b3……bn},现在要实现:if 状态= m set {b1=1, ...,ba = 1}; if 状态 = n set {b1 =1,..., ba1 = 1}

一共有400多万条数据,以前用游标做时每千条要耗时1分钟左右,现在需要把时间压缩到每千条10秒左右

谢谢!
追答
是不是状态不一样 要设置不同的列=1 ?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ghotos
2014-10-23 · TA获得超过280个赞
知道小有建树答主
回答量:435
采纳率:0%
帮助的人:376万
展开全部
你这个为什么要用游标?循环下状态不就可以了!要看你状态有多少种了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式