具有参考分区的直接路径插入?

Jon*_*ler 3 oracle

如何使用直接路径插入通过引用分区将数据快速加载到表中?直接路径插入不能与启用的外键一起使用,并且不能禁用参考分区表的外键。

SQL> create table parent_table(a number primary key)
  2  partition by range(a) (partition p1 values less than (1));

Table created.

SQL> create table child_table(a number not null
  2     ,constraint child_table_fk foreign key (a) references parent_table(a))
  3  partition by reference (child_table_fk);

Table created.

SQL> alter table child_table disable constraint child_table_fk;
alter table child_table disable constraint child_table_fk
*
ERROR at line 1:
ORA-14650: operation not supported for reference-partitioned tables
Run Code Online (Sandbox Code Playgroud)

Jon*_*ler 5

无需禁用外键。即使文档暗示直接路径插入也不能与参考分区一起使用。

LOAD AS SELECT下面的操作演示了使用直接路径插入:

explain plan for insert /*+ append */ into child_table select 1 from dual;

select * from table(dbms_xplan.display(format => 'basic'));

Plan hash value: 2781518217

--------------------------------------------------------
| Id  | Operation                        | Name        |
--------------------------------------------------------
|   0 | INSERT STATEMENT                 |             |
|   1 |  LOAD AS SELECT                  | CHILD_TABLE |
|   2 |   OPTIMIZER STATISTICS GATHERING |             |
|   3 |    FAST DUAL                     |             |
--------------------------------------------------------
Run Code Online (Sandbox Code Playgroud)

如果直接路径插入不适用于引用分区,则是由于许多其他限制之一,例如触发器,不同的外键,可延迟的约束等。