使用bulk collect insert实现大数据快速迁移
来源:互联网 发布:c语言的平方根 编辑:程序博客网 时间:2024/05/22 06:50
在Oracle 数据库中,将一张表的部分字段转换导入到另外一张表的部分字段中,如"insert into t_target(owner,object_name) from t_source;" 。
这也是解决此类数据迁移的的常规操作方法。
如果源表记录数不是很多,操作操作也无妨。
但是若源表记录数一旦超过百万千万,执行时间就长了,占用的回滚段也大。不小心执行失败,又要全部回滚。
有没有更好的方法,加hint 如nologging append, 甚至parallel 。
这些我认为都不是很好的方法,有有一种方法,称之为bulk collect into 。使用它可以减少操作时间。这是基于数据块的插入方式。
(miki西游 @mikixiyou 原文链接: http://mikixiyou.iteye.com/blog/1626906 )
目标表的结构如下:
Sql代码
- create table t_target
- id number,
- owner varchar2(30),
- object_name varchar2(128),
- object_id number,
- xx date,
- yy varchar2(10)
源表为dba_objects ,表结构在数据库中可以查到。
需要将源表dba_objects 中两个字段object_name,owner 两个字段的值复制到t_target 表中。
Sql代码
- declare
- type t_array is table of t_target%rowtype;
- t_data t_array;
- cursor c is
- select null id, owner, object_name, null object_id, null xx, null yy
- from dba_objects;
- begin
- open c;
- loop
- fetch c bulk collect
- into t_data limit 100;
- forall i in 1 .. t_data.count
- insert into t_target values t_data (i);
- exit when c%notfound;
- end loop;
- close c;
- commit;
- end;
- 使用bulk collect insert实现大数据快速迁移
- oracle使用bulk collect insert实现大数据快速迁移
- 使用 BULK INSERT 或 OPENROWSET(BULK...) 导入大容量数据
- 使用bulk collect实现cursor 批量fetch
- 使用bulk collect实现cursor 批量fetch
- 用Forall与bulk collect快速复制表数据
- 使用forall与bulk collect 提升数据割接效率
- BULK INSERT 实现批量数据导入
- oracle 利用bulk collect into 批量insert
- 批量处理数据 bulk collect
- 使用Bulk Insert插入大批量数据
- fetch bulk collect into 使用
- Oracle的bulk collect使用
- 大数据导入之Bulk Insert的一点总结
- 大数据导入之Bulk Insert的一点总结
- Bulk Collect
- bulk collect
- bulk collect
- POJ1936《All in All》
- AJAX技术
- 在Android上实现图像颜色过滤与反转
- SQLServer2008/2005 生成数据字典SQL语句
- Struts2基于注解的Action配置
- 使用bulk collect insert实现大数据快速迁移
- Davinci dm8168算法移植记录
- afinal logo Android的快速开发框架 afinal
- 三大国际主流项目管理体系
- 使用 PHPUnit 和 Selenium 进行测试
- R WGCNA基础(1)——数据过滤
- Category
- 地址空间
- ALV OO相关学习