在过去的几天里,我一直在使用Oracle的SQL * Loader来尝试将数据批量加载到Oracle中。在尝试了不同的选项组合后,我惊讶地发现传统的路径负载比直接路径负载运行得快得多。
关于这个问题的一些事实:
使用传统路径,加载在大约6秒内完成。
对于直接路径加载,加载大约需要20分钟。最糟糕的运行需要1.5小时 完成但服务器根本不忙。
如果启用了skip_index_maintenance,直接路径加载将在2-3秒内完成。
我已经尝试了很多选项,但没有一个能给出明显的改进......难以置信,分类索引,多线程(我在多CPU服务器上运行SQL * Loader)。他们都没有改善这种情况。
这是在SQL * Loader以直接模式运行期间我一直看到的等待事件:
有没有人知道直接路径加载出了什么问题?或者有什么我可以进一步检查,以真正挖掘问题的根本原因?提前谢谢。
答案 0 :(得分:3)
我猜你正在堕落这个
“将相对较少的行加载到大型索引表中
在直接路径加载期间,现有索引在与新索引键合并时会被复制。如果现有索引非常大并且新键的数量非常小,那么索引复制时间可以抵消直接路径加载所节省的时间。“
从何时使用常规路径加载:http://download.oracle.com/docs/cd/B14117_01/server.101/b10825/ldr_modes.htm