分区表及分区索引(9)--删除表分区

来源:互联网 发布:男生办公鼠标推荐 知乎 编辑:程序博客网 时间:2024/05/28 18:43
删除表分区(drop partition)


删除表分区包含两种操作,分别是:


? 删除分区:alter table [tbname] drop partition [ptname];


? 删除子分区:alter table [tbname] drop subpartition [ptname];


除hash分区和hash子分区外,其它的分区格式都可以支持这项操作。




例如,删除分区:
SQL> select partition_name, table_name ,subpartition_count
  2  from user_tab_partitions
  3  where table_name ='T_PART_LIST';
 
PARTITION_NAME                 TABLE_NAME                     SUBPARTITION_COUNT
------------------------------ ------------------------------ ------------------
T_LIST_P1                      T_PART_LIST                                     0
T_LIST_P2                      T_PART_LIST                                     0
T_LIST_P3                      T_PART_LIST                                     0




SQL> select * from t_part_list;
 
         ID NAME
----------- ----------
          1 asdfad
          2 asfda
          3 3333
          3 afasdf
 






SQL> select * from t_part_list partition(t_list_p3);
 
         ID NAME
----------- ----------
          3 3333
          3 afasdf
 
 
 
 
SQL> alter table t_part_list drop partition t_list_p3;
 
Table altered






 
SQL> select * from t_part_list;
 
         ID NAME
----------- ----------
          1 asdfad
          2 asfda
 
 
 
select * from t_part_list partition(t_list_p3)    //肯定不在!在就有鬼了!
 
ORA-02149: 指定的分区不存在




注意:
1.由于是ddl操作,这种删除也会是非常迅速的,因此如果你确认某个分区的数据都要被删除,
使用drop partition会比delete更加高效。如果你的本意是希望删除掉指定的分区但保留数据,你应该使用merge partition,后面也会讲到。




2.同样,如果你在执行该语句时没有指定update indexes子句,也会导致glocal索引的失效,
至于local索引嘛,删除分区时对应的索引分区会被同时删除,但其它分区的local索引不会受到影响。
 
 
 
 
 
 
 
原创粉丝点击