oracle在线重定义表分区,Oracle 表在线重定义替分区表(示例)

SQL> CREATE TABLE TT AS SELECT * FROM DBA_OBJECTS WHERE OBJECT_TYPE IN ('TABLE','INDEX','FUNCTION');--创建原表

表已创建。

SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE('ADMIN', 'TT', DBMS_REDEFINITION.CONS_USE_PK);--检测是否可以进行重定义

BEGIN DBMS_REDEFINITION.CAN_REDEF_TABLE('ADMIN', 'TT', DBMS_REDEFINITION.CONS_USE_PK); END;

*

第 1 行出现错误:

ORA-12089: 不能联机重新定义无主键的表 "ADMIN"."TT"

ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 137

ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 1478

ORA-06512: 在 line 1

SQL> ALTER TABLE TT ADD PRIMARY KEY (OBJECT_ID);--创建主键索引

表已更改。

SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE('ADMIN', 'TT', DBMS_REDEFINITION.CONS_USE_PK);

PL/SQL 过程已成功完成。

SQL> CREATE TABLE MID_TT--创建中间表

2  (

3    OWNER          VARCHAR2(30),

4    OBJECT_NAME    VARCHAR2(128),

5    SUBOBJECT_NAME VARCHAR2(30),

6    OBJECT_ID      NUMBER NOT NULL,

7    DATA_OBJECT_ID NUMBER,

8    OBJECT_TYPE    VARCHAR2(19),

9    CREATED        DATE,

10    LAST_DDL_TIME  DATE,

11    TIMESTAMP      VARCHAR2(19),

12    STATUS         VARCHAR2(7),

13    TEMPORARY      VARCHAR2(1),

14    GENERATED      VARCHAR2(1),

15    SECONDARY      VARCHAR2(1)

16  )TABLESPACE TEST

17   PARTITION BY LIST(OBJECT_TYPE) (

18   PARTITION TAB VALUES('TABLE'),

19   PARTITION IDX VALUES('INDEX'),

20   PARTITION FUNC VALUES('FUNCTION')

21  );

表已创建。

SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE('ADMIN', 'TT', 'MID_TT');--初始化 表的重定义

PL/SQL 过程已成功完成。

SQL> EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE('ADMIN','TT', 'MID_TT');--完成 表的重定义

PL/SQL 过程已成功完成。

SQL> SELECT SEGMENT_NAME,PARTITION_NAME FROM DBA_SEGMENTS WHERE SEGMENT_NAME IN ('TT','MID_TT') AND OWNER = 'ADMIN';--原表的结构与中间表的结构互换

SEGMENT_NAME                                                                      PARTITION_NAME

--------------------------------------------- ------------------------------

MID_TT

TT                                                                                TAB

TT                                                                                IDX

TT                                                                                FUNC

SQL> SELECT TABLE_NAME,INDEX_NAME FROM DBA_INDEXES  WHERE TABLE_NAME IN ('TT','MID_TT') AND OWNER = 'ADMIN';--原表的主键索引也创建到中间表中

TABLE_NAME                     INDEX_NAME

------------------------------ ------------------------------

MID_TT                         SYS_C007791

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将一张 7 亿行的进行在线分区需要经过以下步骤: 1. 首先需要创建分区,可以使用 `CREATE TABLE` 语句创建一个基于范围的分区。 2. 然后需要创建分区索引,可以使用 `CREATE INDEX` 语句创建一个基于范围的分区索引。 3. 然后需要将数据从原迁移到新的分区中。可以使用 Oracle 提供的在线定义(Online Redefinition)功能,该功能允许在不停机的情况下对进行定义。使用在线定义可以将原的数据插入到新的分区中,并在插入的过程中进行分区操作。 4. 最后需要命名原,并将新命名为原的名称。这样做可以确保应用程序仍然可以访问,而不需要修改应用程序代码。 下面是一个基于范围的分区示例,展示如何使用在线定义将原迁移到新的分区中: ``` -- 创建分区 CREATE TABLE my_table_partitioned ( id NUMBER, name VARCHAR2(50), created_date DATE ) PARTITION BY RANGE(created_date) ( PARTITION p1 VALUES LESS THAN (TO_DATE('2020-01-01', 'YYYY-MM-DD')), PARTITION p2 VALUES LESS THAN (TO_DATE('2021-01-01', 'YYYY-MM-DD')), PARTITION p3 VALUES LESS THAN (MAXVALUE) ); -- 创建分区索引 CREATE INDEX my_table_partitioned_idx ON my_table_partitioned(created_date) LOCAL; -- 使用在线定义将原迁移到新的分区中 DECLARE l_table_name VARCHAR2(30) := 'MY_TABLE'; l_new_table_name VARCHAR2(30) := 'MY_TABLE_PARTITIONED'; BEGIN DBMS_REDEFINITION.START_REDEF_TABLE( uname => USER, orig_table => l_table_name, int_table => l_new_table_name, options_flag => DBMS_REDEFINITION.CONS_USE_ROWID ); DBMS_REDEFINITION.COPY_TABLE_DEPENDENTS( uname => USER, orig_table => l_table_name, int_table => l_new_table_name, num_errors => 0, copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS, copy_triggers => TRUE, copy_constraints => TRUE, copy_privileges => TRUE, ignore_errors => FALSE ); DBMS_REDEFINITION.SYNC_INTERIM_TABLE( uname => USER, orig_table => l_table_name, int_table => l_new_table_name ); DBMS_REDEFINITION.FINISH_REDEF_TABLE( uname => USER, orig_table => l_table_name, int_table => l_new_table_name ); END; / -- 命名原,将新命名为原名称 RENAME my_table TO my_table_old; RENAME my_table_partitioned TO my_table; ``` 在上面的示例中,我们创建了一个基于范围的分区 `my_table_partitioned`,并创建了一个基于范围的分区索引 `my_table_partitioned_idx`。然后,我们使用 `DBMS_REDEFINITION` 包中的在线定义功能,将原 `my_table` 中的数据迁移到新的分区 `my_table_partitioned` 中。最后,我们命名了原,并将新命名为原的名称。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值