深入学习分区表及分区索引(9)--删除表分区

删除表分区(droppartition)

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

Ø删除分区:altertable[tbname]droppartition[ptname];

Ø删除子分区:altertable[tbname]dropsubpartition[ptname];

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

例如,删除分区:

JSSWEB>selecttable_name,partition_name

2fromuser_tab_partitionswheretable_name='T_PARTITION_LIST';

TABLE_NAMEPARTITION_NAME

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

T_PARTITION_LISTT_LIST_P1

T_PARTITION_LISTT_LIST_P2

T_PARTITION_LISTT_LIST_P3

T_PARTITION_LISTT_LIST_PD

JSSWEB>altertablet_partition_listdroppartitiont_list_p2;

表已更改。

提示,droppartition时,该分区内存储的数据也将同时删除,例如:

JSSWEB>insertintot_partition_listvalues(1,'a');

..........

--插入一批记录,分布于当前各个分区

..........

JSSWEB>commit;

提交完成。

JSSWEB>select*fromt_partition_list;

IDNAME

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

1a

2b

21a

22b

--单独查询t_list_p3分区,当前有数据

JSSWEB>select*fromt_partition_listpartition(t_list_p3);

IDNAME

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

21a

22b

--删除t_list_p3分区,数据会被同时删除

JSSWEB>altertablet_partition_listdroppartitiont_list_p3;

表已更改。

JSSWEB>select*fromt_partition_listpartition(t_list_p3);

select*fromt_partition_listpartition(t_list_p3)

*

第1行出现错误:

ORA-02149:指定的分区不存在

JSSWEB>select*fromt_partition_list;

IDNAME

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

1a

2b

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

同样,如果你在执行该语句时没有指定updateindexes子句,也会导致glocal索引的失效,至于local索引嘛,删除分区时对应的索引分区会被同时删除,但其它分区的local索引不会受到影响。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值