Data Pump之直接路径与外部表路径

Data Pump通过直接路径与外部表路径这两种方法来完成数据的加载和卸载。直接路径避开了数据库缓冲区缓存。通过直接路径方法导出数据时,Data Pump从磁盘直接读取数据文件,提取和格式化文件内容,最后将
这些内容写为一个转存文件,使用直接路径导入数据,Data Pump读取转储文件,使用文件内容填充表数据
块,最后将这些内容直接写入数据文件,写操作在表的"高水位线"之上完成,其好处在于与前面sql*loader直接路径方式中所描述的是一样的。
     外部表路径使用了数据库缓冲区缓存。即便操纵数据库外部的文件,Data Pump仍然可以像读写内部表
使用数据库缓冲区缓存。导出数据时,Data Pump使用普通的select进程将数据块从数据文件中读入缓存。
为了输出称为一个转储文件,会格式化数据。导入数据时,Data Pump根据转存文件的内容构造标准的insert
语句,并通过将数据块从数据文件读至缓存来执行这些语句,insert操作按照标准的样式在缓存中完成。就数据库而言,尽管外部表Data Pump作业可能很大,但是看上去像普通的select或insert操作一样。和普通的DML
操作一样,使用外部表路径时也会生成撤销和重做。在执行这些作业时,最终用户完全有理由对此产生抱怨:
提交处理过于普通。
    那么,确定Data Pump是使用直接路径还是外部表路径是不好控制的。Data Pump根据对象的复杂性做出决定。只有简单的结构(如不具有活动触发器的堆表才能够通过直接路径进行处理。对于更复杂的对象,如群集表来说,由于为了分解复杂性而要求与SGA进行交互,因此Data Pump必须使用外部表路径。在两种情况下,生成的转存文件完全相同.)
(注:如同其他的DML一样,外部表路径插入操作使用正规的提交,直接路径插入并不使用提交,而是简单的将高水位线向上移动,从而能够包含最新写入的数据块,两种路径生成的Data Pump文件并没有什么区别.)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值