zoukankan      html  css  js  c++  java
  • Oracle重置序列(不删除重建方式)

    Oracle 中的序列我们一般用来生成流水号,所以需要进行重置(如每天凌晨重置一次),我们虽然可以通过重新编译的方式重置序列,可是这种方法会有弊端,比如导致与该序列相关的存储过程或函数失效等等,需要重新编译;于是就需要一种不编译也可以重置序列的方法——

    这种方式,不用删除,利用步长参数,先查出sequence的nextval,记住,把递增改为负的这个值(反过来走),然后再改回来。

     假设需要修改的序列名:seq_name

    1、select seq_name.nextval from dual; //假设得到结果5656

    2、 alter sequence seq_name increment by -5655; //注意是-(n-1)

    3、 select seq_name.nextval from dual;//再查一遍,走一下,重置为1了

    4、  alter sequence seq_name increment by 1;//还原

    可以写个存储过程,以下是完整的存储过程,然后调用传参即可: 

    create or replace procedure seq_reset(v_seqname varchar2) as n number(10);
    tsql varchar2(100);
    begin
    execute immediate 'select '||v_seqname||'.nextval from dual' into n;
    n:=-(n-1);
    tsql:='alter sequence '||v_seqname||' increment by '|| n;
    execute immediate tsql;
    execute immediate 'select '||v_seqname||'.nextval from dual' into n;
    tsql:='alter sequence '||v_seqname||' increment by 1';
    execute immediate tsql;
    end seq_reset;

    转自:http://www.cnblogs.com/huangzhen/archive/2011/09/19/2181257.html
  • 相关阅读:
    setTimeOut 和 setInterval对比
    vue官方源码剖析
    Taro 总结
    地图相交
    vscode 配置文件
    redis持久化的几种方式
    推荐.Net、C# 逆向反编译四大工具利器
    【转】Java 通过JDBC连接Mysql数据库的方法和实例【图文说明】
    【摘】Oracle 11g EM安全证书问题无法访问的解决办法
    MySql 从SQL文件导入
  • 原文地址:https://www.cnblogs.com/programsky/p/4207828.html
Copyright © 2011-2022 走看看