永发信息网

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

答案:2  悬赏:0  手机版
解决时间 2021-03-20 21:31
  • 提问者网友:我的未来我做主
  • 2021-03-20 03:10
oracle 中怎么大批量的执行UPDATE语句
最佳答案
  • 五星知识达人网友:woshuo
  • 2021-03-20 04:03
你可以写一个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块
/追问哦 我刚才没问详细 我意思是说PLSQL命令块是在哪打开 编辑界面是怎么打开的呢?语句的解释很清楚。我的SQL语句是全部放在IF之前么 10W条都放进去?请再教我下,谢谢哈!追答plsql命令块你可以直接在sqlplus里执行
你修改的语句有规率不,没规率那不写死人了,10W条啊
我上面写的意思是,a.2=1到10000时更新a.1=x
全部回答
  • 1楼网友:老鼠爱大米
  • 2021-03-20 04:25
如果系统的数据结果设计的合理,update操作都有一定规律性的。批处理通常采用两种方法:
1、如果要修改的所有行的列、修改数据的来源、计算算法都一样、则一个Update语句就可以解决。
2、如果要修改的所有行的列、修改数据的来源、计算方法虽然不同,但有一定的规律,则采用游标来进行批量修改。
如果要修改的行、列、数据杂乱无章没有一定的规律,则只能一行一行修改了。追问谢谢哈,我这个是属于 你说的最后一种追答如果有10W条记录,一行一行去修改会累死人的,修改肯定有一定规律的。你若把要修改的具体内容贴出来,可以帮你想想办法。追问数据太多 怎么发给你啊?追答具体修改要求说一下。追问数据在EXCLE表内,有两列 我用CONCATENATE把UPDATE语句组成 然后复制到PLSQL里面去执行,一次只能几千条 多了话 PLSQL一直说正在初始化追答按你说的情况,不应该是程序问题。怀疑UNDO表空间不能自动扩展,程序在等待UNDO段释放空间。如果程序中有排序、分组操作的话,还跟TEMP表空间不能自动扩展有关。
你机器具体环境不清楚,只能猜测啦。追问哦 谢谢哦。我看看先
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯