全面學習分割槽表及分割槽索引(9)--刪除表分割槽
刪除表分割槽(drop partition)
刪除表分割槽包含兩種操作,分別是:
Ø 刪除分割槽:alter table [tbname] drop partition [ptname];
Ø 刪除子分割槽:alter table [tbname] drop subpartition [ptname];
除hash分割槽和hash子分割槽外,其它的分割槽格式都可以支援這項操作。
例如,刪除分割槽:
JSSWEB> select table_name,partition_name
2 from user_tab_partitions where table_name='T_PARTITION_LIST';
TABLE_NAME PARTITION_NAME
------------------------------ ------------------------------
T_PARTITION_LIST T_LIST_P1
T_PARTITION_LIST T_LIST_P2
T_PARTITION_LIST T_LIST_P3
T_PARTITION_LIST T_LIST_PD
JSSWEB> alter table t_partition_list drop partition t_list_p2;
表已更改。
提示,drop partition時,該分割槽記憶體儲的資料也將同時刪除,例如:
JSSWEB> insert into t_partition_list values (1,'a');
..........
--插入一批記錄,分佈於當前各個分割槽
..........
JSSWEB> commit;
提交完成。
JSSWEB> select *from t_partition_list;
ID NAME
---------- --------------------------------------------------
1 a
2 b
21 a
22 b
--單獨查詢t_list_p3分割槽,當前有資料
JSSWEB> select *from t_partition_list partition(t_list_p3);
ID NAME
---------- --------------------------------------------------
21 a
22 b
--刪除t_list_p3分割槽,資料會被同時刪除
JSSWEB> alter table t_partition_list drop partition t_list_p3;
表已更改。
JSSWEB> select *from t_partition_list partition(t_list_p3);
select *from t_partition_list partition(t_list_p3)
*
第 1 行出現錯誤:
ORA-02149: 指定的分割槽不存在
JSSWEB> select *from t_partition_list;
ID NAME
---------- --------------------------------------------------
1 a
2 b
由於是ddl操作,這種刪除也會是非常迅速的,因此如果你確認某個分割槽的資料都要被刪除,使用drop partition會比delete更加高效。如果你的本意是希望刪除掉指定的分割槽但保留資料,你應該使用merge partition,後面也會講到。
同樣,如果你在執行該語句時沒有指定update indexes子句,也會導致glocal索引的失效,至於local索引嘛,刪除分割槽時對應的索引分割槽會被同時刪除,但其它分割槽的local索引不會受到影響。
=====================================
檢視前面的連載:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29067253/viewspace-2150329/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle分割槽表基礎運維-09刪除分割槽Oracle運維
- 移動分割槽表和分割槽索引的表空間索引
- oracle分割槽表和分割槽表exchangeOracle
- oracle分割槽表和非分割槽表exchangeOracle
- Oracle分割槽表基礎運維-06分割槽表索引Oracle運維索引
- PostgreSQL/LightDB 分割槽表之分割槽裁剪SQL
- 非分割槽錶轉換成分割槽表
- [oracle] expdp 匯出分割槽表的分割槽Oracle
- PG的非分割槽表線上轉分割槽表
- ORACLE刪除-表分割槽和資料Oracle
- Oracle分割槽表基礎運維-07增加分割槽(3列表分割槽)Oracle運維
- 【MYSQL】 分割槽表MySql
- 增加表分割槽時,為local分割槽索引指定不同表空間的方法索引
- oracle 分割槽表move和包含分割槽表的lob moveOracle
- Oracle分割槽表基礎運維-07增加分割槽(2 HASH分割槽)Oracle運維
- SQL Server表分割槽刪除詳情DSCCSQLServer
- Oracle分割槽表基礎運維-07增加分割槽(1範圍分割槽)Oracle運維
- Oracle分割槽表基礎運維-04列表分割槽Oracle運維
- 【Linux】MBR磁碟分割槽表只能有四個分割槽?Linux
- MySQL 分割槽表探索MySql
- 分割槽表-實戰
- oracle 線上重新定義,普通表改變分割槽表,分割槽表可以更改型別、分割槽欄位等Oracle型別
- Oracle分割槽表基礎運維-05組合分割槽Oracle運維
- Oracle分割槽表基礎運維-02範圍分割槽Oracle運維
- Oracle分割槽表基礎運維-03HASH分割槽Oracle運維
- 分割槽表之自動增加分割槽(11G)
- index_oracle索引梳理系列及分割槽表梳理IndexOracle索引
- mysql分割槽表佔用大量容量處理(最佳化)及歸檔分割槽表MySql
- Oracle分割槽表基礎運維-01分割槽表分類Oracle運維
- HGDB的分割槽表實現SQL Server的分割槽檢視SQLServer
- 非分割槽錶轉換成分割槽表以及注意事項
- SQL SERVER之分割槽表SQLServer
- ORACLE分割槽表梳理系列Oracle
- Spark操作Hive分割槽表SparkHive
- OceaBase 分割槽表建立技巧
- Mysql表分割槽實現MySql
- mysql 進行表分割槽MySql
- Mysql表分割槽實操MySql
- PostgreSQL:傳統分割槽表SQL