再不影响undo空间和其他事务操作情景下,对上亿数据量表的删除方法优化。

在处理上百亿数据量的表时,直接删除会导致undo空间占用增加,影响其他事务效率。为解决此问题,可以将大事务拆分为小批次删除,如每次删除1000万条数据。删除后,需通过授权行移动、回收空间和调整高水位标记(HWM)来优化。此外,更新统计信息有助于提高查询性能。详细操作包括:启用行移动、缩小表空间、删除并收集统计信息。
摘要由CSDN通过智能技术生成

因为表的数据量过大,比如上百亿数据量的表进行删除的话,如果未能及时提交的话,会造成undo空间的占用,导致其他事务操作任务执行时间变长。
所引再删除大数据量表的数据时,需要将进行删除的大事物操作拆分成诺干个小事物。
比如如对A表删除1亿的数据的大事物,可以拆分成每次删除1000W的小事物

因为删除数据后,表的实际存储空间未能释放,需要对数据进行收缩操作。
–授权表支持行移动
execute immediate ‘alter table c##djj.to1_delete_commit enable row movement’;
–回收空间,降低表的HWM
execute immediate ‘alter table c##djj.to1_delete_commit shrink space’;
–收集优化器统计信息
dbms_stats.delete_table_stats(ownname=>‘C##DJJ’,tabname=>‘TO1_DELETE_COMMIT’,cascade_indexes=>true);
dbms_stats.gather_table_stats(ownname=>‘C##DJJ’,tabname=>‘TO1_DELETE_COMMIT’,degree=>8,estimate_percent=>dbms_stats.auto_sample_size);

循环删除数据代码可参考:
https://download.csdn.net/download/u010438126/85045496

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小董的数据库进阶之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值