分区表及分区索引(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索引不会受到影响。
删除表分区包含两种操作,分别是:
? 删除分区: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索引不会受到影响。
- 深入学习分区表及分区索引(9)--删除表分区
- 分区表及分区索引(9)--删除表分区
- 分区表及分区索引(16)--增加和删除索引分区
- 分区表 分区索引 增加 收缩 删除 表分区
- 分区表及分区索引(8)--增加和收缩表分区
- 分区表及分区索引(11)--合并表分区
- 分区表及分区索引(12)--修改list表分区
- 分区表及分区索引(13)--分隔表分区
- 分区表及分区索引(10)--交换分区
- 分区表及分区索引(1)
- Oracle分区表及分区索引
- Oracle分区表及分区索引
- 分区表及分区索引(17)--其它索引分区管理操作
- 深入学习Oracle分区表及分区索引
- 深入学习Oracle分区表及分区索引
- 分区表及分区索引(18)--结束语
- 分区表及分区索引(7.1)--怎样管理
- 分区表及分区索引(7.2)--怎样管理
- android 图标设计
- 分区表及分区索引(8)--增加和收缩表分区
- web工程 编译 @Override 错误
- 将datatable写入XML文件
- netstat命令的一些说明
- 分区表及分区索引(9)--删除表分区
- linux 下遍历文件夹下的所有文件
- 引用 linux ioctl函数
- MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- 分区表及分区索引(10)--交换分区
- Big endian and Little endian
- Windows下编译安装perl Module
- 分区表及分区索引(11)--合并表分区
- jQuery.extend 函数详解