Oracle如何最快的删除大数据量表中的多个字段-亲测有效


一、查询表数据量

-- 7945387
SELECT /*+ parallel(8) */COUNT(1) sl FROM ets.tzq_invoice_batch_ti;
-- 7945304
SELECT /*+ parallel(8) */COUNT(1) sl FROM ets.tzq_invoice_batch_t;

二、正常情况下,删除一个字段要18分钟

正常情况下,删除一个字段要18分钟(18:17)

alter table TZQ_INVOICE_BATCH_TI drop column supplier_name;

三、测试过程

3.1、创建临时表

下面为测试过程,注释掉长度>500的字段,创建临时表
执行耗时:37s

CREATE TABLE TZQ_INVOICE_BATCH_TI_TEMP 
tablespace TZQ_DATA
nologging
AS
SELECT batch_id
      ,batch_number
      ,invoice_number
      ,batch_status
      ,bussiness_type
      ,amount
      ,currency
      ,supplier_code
      --,supplier_name
      --,description
      ,due_date
      ,process_status
      ,process_date
  FROM tzq.tzq_invoice_batch_ti;

3.2、删除原表:14s

耗时:14s

drop table tzq_invoice_batch_ti PURGE;

3.3、重命名临时表为原表:0.2s

ALTER TABLE TZQ_INVOICE_BATCH_TI_TEMP RENAME TO TZQ_INVOICE_BATCH_TI;

3.4、重新授权

--重新授权 Grant/Revoke object privileges 
	grant select on TZQ_APWF_INVOICE_BATCH_TI to PUB_TZQ_VIEW;

3.5、参考(重建索引、主键) - 使用nologging以及parallel快速重新添加索引

使用nologging以及parallel快速重新添加索引

create index IND_Afile on A(field2) tablespace ATEMP nologging parallel 6;

3.6、重建主键

alter table A add constraint PK_field primary key (field1) using index tablespace ATEMP  nologging;

–参考资料
–https://blog.csdn.net/sdmanooo/article/details/54970638

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Tzq@2018

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

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

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

打赏作者

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

抵扣说明:

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

余额充值