Oracle-—系统包使用
文章目录
系统包
dbms_redefinition
功能介绍:该包体可以实现将Oracle库下的表在线改为分区结构或者重新定义;
说明:在检查表是否可以重定义和开始重定义的过程中,按照表是否存在主键,参数 options_flag有如下两种选择:
1)dbms_redefinition.cons_use_rowid
2)dbms_redefinition.cons_use_pk
-
step_1:检测是否可以重定义
exec dbms_redefinition.can_redef_table('schema_name', '$source_tab',dbms_redefinition.cons_use_pk);
-
step_2:重定义表
exec dbms_redefinition.start_redef_table('schema_name', '$source_tab', '$target_tab',null,dbms_redefinition.cons_use_pk);
-
step_3:同步数据到新表
execute dbms_redefinition.sync_interim_table('schema_name','$source_tab','$target_tab');
-
step_4:结束表重定义
exec dbms_redefinition.finish_redef_table('schema_name', '$source_tab', '$target_tab');
-
step_5:强制退出重定义
exec dbms_redefinition.abort_redef_table('schema_name', '$source_tab', '$target_tab');
验证结论:
A:从模板表到正式表的重新定义,实际是交换了2个表的差异部分;
B:从模板表到正式表的差异交换,包括数据部分,空表变为有数据的表,同样有数据的表会变为空表;
======================================== over ========================================
原文地址:https://blog.csdn.net/weixin_38938108/article/details/144130770
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!