如何高效率刪除大表歷史資料
清理大表歷史資料
透過將非分割槽表Online Redefinition轉換為以刪除條件為Range範圍分割槽的Partition-ed Table,再直接Truncate Partiton的方法來加速歷史資料的清理,
同時又不影響業務的線上。
create table order_history as select * from dba_objects;
select count(*) from order_history;
select count(*) from order_history where created < sysdate-365;
COUNT(*)
———-
49983
收集統計資訊
exec dbms_stats.gather_table_stats('SCOTT','ORDER_HISTORY');
create table order_history_int(
OWNER VARCHAR2(30),
OBJECT_NAME VARCHAR2(128),
SUBOBJECT_NAME VARCHAR2(30),
OBJECT_ID NUMBER,
DATA_OBJECT_ID NUMBER,
OBJECT_TYPE VARCHAR2(19),
CREATED DATE,
LAST_DDL_TIME DATE,
TIMESTAMP VARCHAR2(19),
STATUS VARCHAR2(7),
TEMPORARY VARCHAR2(1),
GENERATED VARCHAR2(1),
SECONDARY VARCHAR2(1))
partition by range(created)
( partition p1 values less than (to_date('2010-01-01','YYYY-MM-DD')) tablespace users,
partition p2 values less than (to_date('2011-01-01','YYYY-MM-DD')) tablespace users,
partition p3 values less than (to_date('2012-01-01','YYYY-MM-DD')) tablespace users,
partition p4 values less than (to_date('2013-01-01','YYYY-MM-DD')) tablespace users,
partition p5 values less than (maxvalue) tablespace users);
begin
dbms_redefinition.can_redef_table(uname => 'SCOTT',
tname => 'ORDER_HISTORY',
options_flag => DBMS_REDEFINITION.CONS_USE_ROWID);
end;
/
begin
DBMS_REDEFINITION.START_REDEF_TABLE(uname => 'SCOTT',
orig_table => 'ORDER_HISTORY',
int_table => 'ORDER_HISTORY_INT',
options_flag => DBMS_REDEFINITION.cons_use_rowid);
end;
/
SQL> select count(*) from ORDER_HISTORY_INT;
COUNT(*)
———-
50731
DECLARE
num_errors PLS_INTEGER;
BEGIN
DBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'SCOTT',
orig_table => 'ORDER_HISTORY',
int_table => 'ORDER_HISTORY_INT',
copy_indexes => 0,
copy_triggers => TRUE,
copy_constraints => FALSE,
copy_privileges => TRUE,
ignore_errors => FALSE,
num_errors => num_errors,
copy_statistics => TRUE);
END;
/
begin
dbms_redefinition.finish_redef_table(uname => 'SCOTT',
orig_table => 'ORDER_HISTORY',
int_table => 'ORDER_HISTORY_INT');
end;
/
alter table ORDER_HISTORY truncate partition p1;
alter table ORDER_HISTORY truncate partition p2;
alter table ORDER_HISTORY truncate partition p3;
SQL> select count(*) from ORDER_HISTORY;
COUNT(*)
———-
748
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23732248/viewspace-2285224/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- python 刪除大表資料Python
- Percona-Toolkit 之 pt-archiver 刪除歷史資料Hive
- git刪除歷史中的某個大檔案Git
- git 刪除歷史指定檔案Git
- 如何刪除遠端桌面歷史連線記錄
- 【C/C++】資料庫刪除大表C++資料庫
- MySQL刪除資料表MySql
- 簡單介紹mysql如何刪除資料表和關聯的資料表刪除詳情MySql
- Jenkins批量刪除構建歷史版本Jenkins
- 如何刪除資料庫下的所有表(mysql)資料庫MySql
- svn歷史版本刪除(為svn庫瘦身)
- MySQL如何優雅的刪除大表MySql
- win10桌面背景歷史怎麼刪除_win10刪除桌面桌布歷史記錄教程Win10
- MYSQL下如何安全的快速刪除大表MySql
- 【北亞資料恢復】誤刪除oracle表和誤刪除oracle表資料的資料恢復方法資料恢復Oracle
- MySQL超大表刪除資料過程MySql
- ORACLE刪除-表分割槽和資料Oracle
- sql 多表關聯刪除表資料SQL
- PostgreSQL刪除表中重複資料SQL
- 如何刪除Removable Drives資料夾?REM
- windows10更新記錄刪除_怎樣刪除win10更新歷史記錄WindowsWin10
- 刪除a表中和b表相同的資料
- mysql 刪除表中重複的資料MySql
- 刪除資料
- Win10系統中Microsoft Edge如何刪除歷史記錄,Cookie、快取Win10ROSCookie快取
- whk我【資料刪除】你個【資料刪除】的
- python列表資料如何增加和刪除Python
- MySQL資料庫表誤刪除恢復(一)MySql資料庫
- Oracle中刪除表中的重複資料Oracle
- 資料科學的歷史,從洞穴壁畫到大資料資料科學大資料
- indexedDB 刪除資料Index
- 刪除elasticsearch資料Elasticsearch
- win10執行欄輸入歷史怎麼刪除 win10電腦的執行欄歷史記錄如何清理Win10
- Python如何遞迴刪除空資料夾Python遞迴
- Laravel 如何實現資料的軟刪除Laravel
- sql server如何刪除前1000行資料SQLServer
- 如何使用 EF Core 7 批次刪除資料
- 教你如何刪除Mac下的iCloud資料?MacCloud