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 ========================================

相关推荐
软件派11 小时前
高斯数据库使用心得——从性能优化到行业实践的深度解析
数据库·oracle
晴天¥14 小时前
Oracle DB 的相关管理工具
数据库·oracle
_oP_i15 小时前
oracle 免费安装版本
数据库·oracle
川石课堂软件测试16 小时前
Android和iOS APP平台测试的区别
android·数据库·ios·oracle·单元测试·测试用例·cocoa
香气袭人知骤暖17 小时前
MVCC为什么不能完全解决幻读问题
数据库·oracle
lkbhua莱克瓦2420 小时前
进阶-SQL优化
java·数据库·sql·mysql·oracle
float_六七1 天前
数据库三级模式:逻辑与物理的完美架构
数据库·oracle
曹牧1 天前
Oracle:导出SQL
数据库·oracle
Nerd Nirvana2 天前
数据库模型全景:从原理到实践的系统性指南
数据库·oracle·电力行业
BryceBorder2 天前
SCAU--数据库
数据库·oracle·dba