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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值