免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5250 | 回复: 2
打印 上一主题 下一主题

[数据库] oracle中inset select的性能问题? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-02-16 18:12 |只看该作者 |倒序浏览
场景是这样的:要把表tableB中的数据全部插入到tableA中。tableB中的数据有10多亿条记录,占用磁盘空间100多G。
准备执行以下语句:
insert into tableA (col1,col2,col3)
select col1,col2,col3 from tableB;
commit;

现在的问题是:
1. 因为tableB中的数据巨大,这儿有没有必要采取分批插入提交的方式?分批插入提交会不会带来性能的很大提升?比如从tableB中找到10000条插入提交一次。
2. 如果不分批操作,对性能是否有影响?除了性能方面的影响之外会不会报错?
3. 因为tableB中的数据有100多G,肯定无法一次装入内存中。那oracle是如何把这个多的数据查询出来再装入内存再插入到tableA中的内?这个过程具体是如何实现的?oracle会自动分批插入?

以上向达人求教?

论坛徽章:
0
2 [报告]
发表于 2014-02-16 18:25 |只看该作者
问题补充:
对于这种100多G的巨量数据的插入,有没有必要手动编码设置成分批提交?undo表空间中肯定是没有这么大空间的,那oracle是如何处理这个问题的呢?

论坛徽章:
0
3 [报告]
发表于 2014-02-17 08:28 |只看该作者
楼主你这个问题,让我想起了tom提出的“打造自己的并行”的策略,既然是两个表之间的简单“复制”,建议两个方法:

第一个: 可以将这些数据归类,设计合理的条件在多个会话中同时插入,实现并行处理。

第二个:可以采用复制表的方法,如: create table tableB as select col1,col2,col3 from tableA
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP