oracle 中怎么大批量的执行UPDATE语句

比如有很多update语句,比如:updateaseta.1=xwherea.2=yupdateaseta.1=x1wherea.2=y1有很多这个语句10W行。怎么能一... 比如有很多update语句,比如:
update a set a.1=x where a.2=y
update a set a.1=x1 where a.2=y1

有很多这个语句10W行。
怎么能一次性运行命令让他一条一条去完成啊?
本人菜鸟一只,求大神指点。在线等!!谢谢啊 分不多!
展开
 我来答
c6iz
2012-09-01 · TA获得超过1417个赞
知道大有可为答主
回答量:1426
采纳率:100%
帮助的人:1048万
展开全部
你可以写一个PLSQL命令块通过执行UPDATE命令
begin
for i in 1 .. 100000
loop
update a set a.1=x where a.2=i
if mod(i,5000)=0
then
commit;
end if;
end loop;
end;
/
更多追问追答
追问
可以详细点么  我不是很懂。 谢谢啦
追答
begin
for i in 1 .. 100000
loop ---到这是表示i从1到10W循环10次,每次i值加1
update a set a.1=x where a.2=i ; --你的UPDATE语句
if mod(i,5000)=0
then
commit;
end if; ---这个IF语句表示每更新5000条记录提交一次
end loop; --结束循环
end; --结束PLSQL块
/
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
随o天
2012-09-01 · TA获得超过3158个赞
知道大有可为答主
回答量:1740
采纳率:71%
帮助的人:2035万
展开全部
如果系统的数据结果设计的合理,update操作都有一定规律性的。批处理通常采用两种方法:
1、如果要修改的所有行的列、修改数据的来源、计算算法都一样、则一个Update语句就可以解决。
2、如果要修改的所有行的列、修改数据的来源、计算方法虽然不同,但有一定的规律,则采用游标来进行批量修改。
如果要修改的行、列、数据杂乱无章没有一定的规律,则只能一行一行修改了。
更多追问追答
追问
谢谢哈,我这个是属于 你说的最后一种
追答
如果有10W条记录,一行一行去修改会累死人的,修改肯定有一定规律的。你若把要修改的具体内容贴出来,可以帮你想想办法。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式