Oracle更新(update)某大数据量的表的最优方法(语句)请教。解决送分。

updatet_sjzh_gisoid2pmsoidaset(a.mpid,a.yxdw,A.SBID,a.yxbh)=(selectb.OBJ_ID,b.ywdw,B.... update t_sjzh_gisoid2pmsoid a set (a.mpid,a.yxdw,A.SBID,a.yxbh)=(select b.OBJ_ID,b.ywdw,B.OBJ_ID,B.yxbh from v_asset_sbbm b where a.globeid=b.SBBM)
WHERE (a.sbid IS NULL) ;
更新语句如上, t_sjzh_gisoid2pmsoid 表有数据约170万;v_asset_sbbm 视图有数据约150万。
直接使用update更新的话,耗时非常久非常久(远远超过3个小时),请教大神,是否有快一些的方法。
【 a.globeid及b.SBBM字段对应索引已创建】
展开
 我来答
faraway_xj
推荐于2016-07-29 · TA获得超过2675个赞
知道大有可为答主
回答量:2482
采纳率:0%
帮助的人:1324万
展开全部
建议你通过某个条件把这150万条记录,分成多个部分,写个存储过程,依次执行,执行完一部分就提交一部分。
这样即即减少了对内存的要求,也防止玩意update出错,还要花费大量的时间在回滚上。
追问
有没有具体一点的办法呢
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式