我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ORACLE 在线表重定义

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ORACLE 在线表重定义

ORACLE 在实际中一些表由于业务量增大,一些原先规划不是很大的表的数据量大增,为了优化要把这些表从普通表变成分区表。现在就介绍ORACLE自带的一种技术来处理这种情况-这种技术叫在线表重定义。

第一步建立临时表:

create table test_table

( ID NUMEBER(10) NOT NULL,

 STATUS VARCHAR2(30) NULL,

CREATE_DATE  DATE

)PARTITION BY RANGE(CREATE_DATE)
( PARTITION part23 VALUES LESS THAN (TO_DATE('2010-09-24','YYYY-MM-DD')),
 PARTITION part24 VALUES LESS THAN(TO_DATE('2010-09-25', 'YYYY-MM-DD')),
 PARTITION Part25 VALUES LESS THAN(TO_DATE('2010-09-26', 'YYYY-MM-DD')),
 PARTITION partmax VALUES LESS THAN(MAXVALUE)
);

alter table test_table add constraint test_table_pk primary key(id);

第二步 判断目标数据表是否可以进行重定义 。利用的DBMS_REDEFINITION包的CAN_REDEF_TABLE的方法进行判断。

exec dbms_redefinition.can_redef_table('user','table',dbms_redefinition.cons_use_pk);

使用cons_use_pk重定义的时候创建的物化视图是基于普通的刷新模式.

也可以用ROWID的方法

exec dbms_redefinition.can_redef_table('user','table',dbms_redefinition.cons_use_rowid);

使用cons_use_rowid重定义的时候创建的物化视图是基于ROWID刷新的.

第三步 开始重定义

exec dbms_redefinition.start_redef_table('user', 'table', 'test_table');

同步临时表与原始表中的数据

exec dbms_redefinition.sync_interim_table('user', 'table', 'test_table');

开始复制表的属性

declareCLAR

num_errors PLS_INTEGER; 

BEGIN 

  DBMS_REDEFINITION.COPY_TABLE_DEPENDENTS('user','table','test_table',

   DBMS_REDEFINITION.CONS_ORIG_PARAMS, TRUE, TRUE, TRUE, TRUE, num_errors); 

END; 

包括索引,规则,促发器

完成重定义

exec dbms_redefinition.finish_redef_table('user', 'table', 'test_table');



_pk);




免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ORACLE 在线表重定义

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ORACLE分区表转换在线重定义DBMS_REDEFINITION

目录一、DBMS_REDEFINITION(在线重定义)使用在线重定义的一些限制条件:DBMS_REDEFINITION包:二、在线重定义表的步骤1.创建未分区的表2.确认表是否存在主键,表空间是否足够,收集表统计信息。3.调用DBMS_R
2022-07-07

oracle表分区的定义是什么

Oracle表分区是将表数据按一定的规则分割存储在不同的分区中,以提高查询性能和管理数据的效率。通过表分区,可以将表数据存储在不同的物理存储位置上,实现数据的快速查询和管理。常见的表分区方式包括范围分区、列表分区、哈希分区和复合分区等。通过
oracle表分区的定义是什么
2024-04-09

怎么在Java中自定义线程池

这篇文章给大家介绍怎么在Java中自定义线程池,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。【1】接口定义public interface IThreadPool { /**
2023-06-06

oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在

oracle删除表,如果表不存在,就报错,在跑大型脚本(脚本长且耗时的时候)比较麻烦,一般希望的是点开始然后脚本运行到结束,不可能一直盯着屏幕等弹出提示手工点掉,mysql就很好有drop table if not exist功能CREATE OR REPLA
2020-01-13

怎么在java项目中自定义线程池

怎么在java项目中自定义线程池?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。使用线程池时,可以使用 newCachedThreadPool()或者 newFi
2023-05-31

编程热搜

目录