数据库重建索引的一个思路

最近需求涉及到一个保存实时数据的功能,使用Oracle数据库。

保存的数据量不大,但是覆盖会比较频繁。

造成了一个就几万数据的表,序列可能都达到千万了。

这个在Oracle环境下其实还好,但是需要兼容pgsql环境,使用了serial自增序列,最大21亿,因此了解了下关于重置序列的方式。

 

方案一:

先drop再create

优点:简单

缺点:在服务运行过程中执行存在风险

 

方案二:

利用负数步长将序列值减小,再恢复步长为1

 

此次使用方案二在程序中定期重置序列

存储过程样例如下:

create or replace procedure SEQ_RESET
as NUM number(10);
  SQL varchar2(100);
  begin
    execute immediate 'select SEQ_TEST.nextval from dual' into NUM;
    if NUM > 10000000
    THEN
      NUM:=-(NUM - 1);
      SQL:='alter sequence SEQ_TEST increment by '|| NUM;
      execute immediate SQL;
      execute immediate 'select SEQ_TEST.nextval from dual';
      execute immediate 'alter sequence SEQ_TEST increment by 1';
    END IF ;

  end SEQ_RESET;
/

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值