Oracle 将普通表转换为分区表

DB:11.2.0.30

将普通表转换为区分表

一.利用原表重建分区表
SQL>create table yoon ( id number primary key ,time date );

Table created.

SQL>insert into yoon select rownum,created from dba_objects;

74930 rows created.

SQL>select count(*) from yoon;
COUNT(*)
----------
74930

SQL>create table yoon_new (ID,TIME) partition by range(time)
(partition p1 values less than (to_date(‘2011-10-01‘,‘YYYY-MM-DD‘)),
partition p2 values less than (to_date(‘2012-10-01‘,‘YYYY-MM-DD‘)),
partition p3 values less than (to_date(‘2013-10-01‘,‘YYYY-MM-DD‘)),
partition p4 values less than (MAXVALUE))
as select id,time from yoon;

Table created.

SQL>select table_owner,table_name,partition_name from dba_tab_partitions where table_name=‘YOON_NEW‘;

TABLE_OWNER                    TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------ ------------------------------
YOON                           YOON_NEW                       P1
YOON                           YOON_NEW                       P2
YOON                           YOON_NEW                       P3
YOON                           YOON_NEW                       P4

SQL>alter table yoon rename to yoon_old;

Table altered.

SQL>alter table yoon_new rename to yoon;

Table altered.

SQL>select count(*) from yoon partition(p1);

COUNT(*)
----------
     74445
     
SQL> select count(*) from yoon partition(p2);

COUNT(*)
----------
         0

SQL> select count(*) from yoon partition(p3);

COUNT(*)
----------
         0
         
SQL> select count(*) from yoon partition(p4);

COUNT(*)
----------
       485
       
优点:方法简单、易用,由于采用DDL语句,不会产生UNDO,且只产生少量REDO,效率相对较高,而且建表完成后数据已经在分布到各个分区中了.
缺点:1.适用于修改不频繁的表,在闲时进行操作,表的数据量不宜太大.
      2.表太大,在导入数据的时候会产生大量的UNDO;非要采用这种方式,将数据分批次导入.

二.交换分区
SQL> create table yoon ( id number primary key,time date ) ;

Table created.

SQL> insert into yoon select rownum,created from dba_objects;

74930 rows created.

SQL> commit;

Commit complete.

SQL> create table yoon_new ( id number primary key,time date ) partition by range(time)
  2  (partition p1 values less than (to_date(‘2015-10-01‘,‘YYYY-DD-MM‘)),
  3   partition p2 values less than (maxvalue));

Table created.

SQL> ALTER TABLE YOON_NEW EXCHANGE PARTITION P1 WITH TABLE YOON ;

Table altered.

SQL> select count(*) from yoon;

COUNT(*)
----------
         0
         
SQL> select count(*) from yoon_new;

COUNT(*)
----------
     74930
     
SQL> alter table yoon rename to yoon_old;

Table altered.

SQL> alter table yoon_new rename to yoon;

Table altered.

SQL> select table_owner,table_name,partition_name from dba_tab_partitions where table_name=‘YOON‘;

TABLE_OWNER                    TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------ ------------------------------
YOON                           YOON                           P1
YOON                           YOON                           P2

三.在线重定义

SQL> create table yoon ( id number primary key,time date ) ;

Table created.

SQL> insert into yoon select rownum,created from dba_objects;

74930 rows created.

SQL> commit;

Commit complete.

SQL> EXEC DBMS_REDEFINITION.can_redef_table(user,‘YOON‘,DBMS_REDEFINITION.CONS_USE_PK);

PL/SQL procedure successfully completed.

SQL> create table yoon_new ( id number primary key,time date ) partition by range(time)
  2  (partition p1 values less than (to_date(‘2011-01-01‘,‘YYYY-DD-MM‘)),
  3   partition p2 values less than (to_date(‘2012-01-01‘,‘YYYY-DD-MM‘)),
  4   partition p3 values less than (to_date(‘2013-01-01‘,‘YYYY-DD-MM‘)),
  5   partition p4 values less than (maxvalue));

Table created.

SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER,‘YOON‘,‘YOON_NEW‘,‘ID ID,TIME TIME‘,DBMS_REDEFINITION.CONS_USE_PK);

PL/SQL procedure successfully completed.

SQL> EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(‘YOON‘,‘YOON‘,‘YOON_NEW‘);

PL/SQL procedure successfully completed.

S
QL> select table_name from user_tables;

TABLE_NAME
------------------------------
YOON_NEW
YOON

SQL> select count(*) from yoon_new;

COUNT(*)
----------
     74930

SQL> select count(*) from yoon;

COUNT(*)
----------
     74930

SQL> select table_owner,table_name,partition_name from dba_tab_partitions where table_name=‘YOON‘;

TABLE_OWNER                    TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------ ------------------------------
YOON                           YOON                           P1
YOON                           YOON                           P2
YOON                           YOON                           P3
YOON                           YOON                           P4

在线重定义能够保证数据的一致性,在大部分时间中,表YOON都可以正常进行DML操作,在切换的瞬间锁表,具有狠高的可用性,具有狠强的灵活性,能够满足各种不同的需求.可以在切换前建立各种约束,做到切换后不用任何额外的管理操作.

时间: 2024-11-05 16:09:21

Oracle 将普通表转换为分区表的相关文章

oracle 11g在线重定义 普通表变分区表

第一种方法使用主键id进行重定义--createusertestidentifiedby1accountunlock;--grantresource--grantcreateanytable,alteranytable,dropanytable,lockanytable,selectanytabletotest;--<1>创建测试表,以下使用在线重定义把表转换为分区表,created为分区键,object_id为.. v.17173.com/playlist_17354294.htmlv.17

使用exchange方式切换普通表到分区表

随着数据库数据量的不断增长,有些表需要由普通的堆表转换为分区表的模式.有几种不同的方法来对此进行操作,诸如导出表数据,然后创建分区表再导入数据到分区表:使用EXCHANGE PARTITION方式来转换为分区表以及使用DBMS_REDEFINITION来在线重定义分区表.本文描述的是使用EXCHANGE PARTITION方式来实现,下面是具体的操作示例. 有关具体的dbms_redefinition在线重定义表的原理及步骤可参考:基于 dbms_redefinition 在线重定义表     

使用DBMS_REDEFINITION在线切换普通表到分区表

随着数据库数据量的不断增长,有些表须要由普通的堆表转换为分区表的模式.有几种不同的方法来对此进行操作.诸如导出表数据,然后创建分区表再导入数据到分区表.使用EXCHANGE PARTITION方式来转换为分区表以及使用DBMS_REDEFINITION来在线重定义分区表.本文描写叙述的是使用DBMS_REDEFINITION来实现,以下是详细的操作演示样例. 有关详细的dbms_redefinition在线重定义表的原理及步骤可參考:基于 dbms_redefinition 在线重定义表    

Oracle 分区表的新增、修改、删除、合并。普通表转分区表方法

一. 分区表理论知识 Oracle提供了分区技术以支持VLDB(Very Large DataBase).分区表通过对分区列的判断,把分区列不同的记录,放到不同的分区中.分区完全对应用透明.Oracle的分区表可以包括多个分区,每个分区都是一个独立的段(SEGMENT),可以存放到不同的表空间中.查询时可以通过查询表来访问各个分区中的数据,也可以通过在查询时直接指定分区的方法来进行查询. When to Partition a Table什么时候需要分区表,官网的2个建议如下: Tables g

ORACLE 五种表的优缺点总结

ORACLE 五种表的优缺点总结: 1.普通表(heap table):适合大部分设计场景,有长处也有缺点. 长处: a,语法简单方便 b,适合大部分场景 缺点: a,更新日志开销较大 b,Delete无法释放空间(HWM High Water Mark不下降) c,表记录太大检索太慢 d,索引回表读开销非常大 e,即便有序插入,也非常难保证有序读出 2,全局暂时表:适合接口表设计 长处: a,高效删除 b,产生非常少的日志 c,不同的SESSION独立,不产生锁 缺点: a,语法特别 b,数据

ORACLE修改用户表所属表空间的步骤

ORACLE修改用户表所属表空间的步骤 使用脚本进行修改.据目前所了解,正长情况下需要修改表的空间和表的索引的空间,如果涉及到BOLB字段的表,修改的方式又不一样了!正常情况下的修改脚本:1.修改表的空间alter table TABLE_NAME move tablespace TABLESPACENAME 查询当前用户下的所有表select 'alter table  '|| table_name ||'  move tablespace tablespacename;'  from use

ORACLE: 查询(看)表的主键、外键、唯一性约束和索引

ORACLE: 查询(看)表的主键.外键.唯一性约束和索引 1.查找表的所有索引(包括索引名,类型,构成列) select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 表名 2.查找表的主键(包括名称,构成列): select cu.* from user_co

[转]Oracle DB 执行表空间时间点恢复

• 列出在执行表空间时间点恢复(TSPITR) 时会发生的操作 • 阐释TSPITR 使用的术语的定义 • 确定适合将TSPITR 用作解决方案的情况 • 确定时间点恢复的正确目标时间 • 确定不能使用TSPITR 的情况以及解决方法 • 执行自动TSPITR 表空间时间点恢复(TSPITR):概念 • 通过执行TSPITR 可将一个或多个表空间快速恢复到以前的某个时间. • 执行TSPITR 不会影响数据库中其它表空间或对象的状态. 使用RMAN 自动表空间时间点恢复(TSPITR) 可将Or

Oracle的锁表与解锁

Oracle的锁表与解锁 SELECT /*+ rule */ s.username, decode(l.type,'TM','TABLE LOCK', 'TX','ROW LOCK', NULL) LOCK_LEVEL, o.owner,o.object_name,o.object_type, s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser FROM v$session s,v$lock l,dba_objects o WHERE