达梦数据库的索引如何失效与重建

有很多应用场景需要往里灌大量的数据,为提高速度,常常的方法就是失效索引,下面就介绍一下方法。以失效表的索引为例,如果需要失效某个用户下所有的索引,则去掉where条件table_name=‘TEST_TABLE’。
–数据量
select count() from “SYSDBA”.“TEST_TABLE”;–100000000
CREATE INDEX “IDX_WYB_NAME” ON “SYSDBA”.“TEST_TABLE”(“NAME” ASC) STORAGE(ON “TEST.DBF”, CLUSTERBTR) ;
CREATE INDEX “IDX_WYB_PRIPID” ON “SYSDBA”.“TEST_TABLE”(“PRIPID” ASC) STORAGE(ON “TEST.DBF”, CLUSTERBTR) ;
–失效索引
declare
v_cnt int;
begin
for rec in(select INDEX_NAME from user_indexes where table_name=‘TEST_TABLE’ and INDEX_TYPE=‘NORMAL’ and UNIQUENESS=‘NONUNIQUE’)
loop
execute immediate ‘ALTER INDEX “SYSDBA”.’||rec.INDEX_NAME||’ UNUSABLE;’;
end loop;
end;
/
–执行成功, 执行耗时12毫秒
select count(
) from “SYSDBA”.“TEST_TABLE”;–100000000

–重建索引
–1、REBUILD
declare
v_cnt int;
begin
for rec in(select INDEX_NAME from user_indexes where table_name=‘TEST_TABLE’ and INDEX_TYPE=‘NORMAL’ and UNIQUENESS=‘NONUNIQUE’)
loop
execute immediate ‘ALTER INDEX “SYSDBA”.’||rec.INDEX_NAME||’ REBUILD;’;
end loop;
end;
/
–执行成功, 执行耗时6分 23秒 239毫秒

–2、REBUILD ONLINE
declare
v_cnt int;
begin
for rec in(select INDEX_NAME from user_indexes where table_name=‘TEST_TABLE’ and INDEX_TYPE=‘NORMAL’ and UNIQUENESS=‘NONUNIQUE’)
loop
execute immediate ‘ALTER INDEX “SYSDBA”.’||rec.INDEX_NAME||’ REBUILD ONLINE;’;
end loop;
end;
/
–执行成功, 执行耗时6分 1秒 450毫秒
–2、更新列统计信息
stat 100 on TEST_TABLE(PRIPID);
–执行成功, 执行耗时1分 15秒 279毫秒
stat 100 on TEST_TABLE(NAME);
–执行成功, 执行耗时28秒 773毫秒

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值