分享更有价值
被信任是一种快乐

数据库中如何高效率删除大表历史数据

文章页正文上

这篇文章主要介绍数据库中如何高效率删除大表历史数据,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!清理大表历史数据
通过将非分区表Online Redefinition转换为以删除条件为Range范围分区的Partition-ed Table,再直接Truncate Partiton的方法来加速历史数据的清理,
同时又不影响业务的在线。
create table order_histo免费主机域名ry as select * from dba_objects;
select count(*) from order_history;
select count(*) from order_history where created
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(*)
———-
50731DECLARE
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以上是“数据库中如何高效率删除大表历史数据”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注云技术行业资讯频道!

相关推荐: Keepalived+Mysql如何配置主主复制

小编给大家分享一下Keepalived+Mysql如何配置主主复制,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!安装环境:软件包:keepalived-1.3.5.tar.gzmys…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册