oracle序列

    1. oracle序列建立语法
CREATE SEQUENCE sequence  //建立序列名称
       [INCREMENT BY n]  //递增的序列值是n 若是n是正数就递增,若是是负数就递减 默认是1
       [START WITH n]    //开始的值,递增默认是minvalue 递减是maxvalue
       [{MAXVALUE n | NOMAXVALUE}] //最大值
       [{MINVALUE n | NOMINVALUE}] //最小值
       [{CYCLE | NOCYCLE}] //循环/不循环
       [{CACHE n | NOCACHE}];//分配并存入到内存中
    2. oracle建立语法中的缓存做用
       (参考:http://zhidao.baidu.com/link?url=5rNZnGdRJ9JPUVng3LrXtQ2pIuwTmpeEM4WRh7ibFWnXSJEDSKx1igdCEy0grG75wxH3WC5XOSaMK-e5k1xmOK)
       当大量语句发生请求,申请序列时,为了不序列在运用层实现序列而引发的性能瓶颈。Oracle序列容许将序列提早生成 cache x个先存入内存,在发生大量申请序列语句时,可直接到运行最快的内存中去获得序列。但cache个数也不能设置太大,由于在数据库重启时,会清空内存信息,预存在内存中的序列会丢失,当数据库再次启动后,序列从上次内存中最大的序列号+1 开始存入cache x个。
    3. 序列的查询(以自增序列为例)
       建立自增序列:
create sequence s1 increment by 1 start with 1 maxvalue 999 cycle cache 10;
       <1> 普通查询     
select s1.nextval 普通序列号 from dual;

       <2> 固定格式的查询----位数补零          
select lpad(s1.nextval,3,'0') 补零序列号 from dual;

       <3> 当前时间与自增序列结合.         
select to_char(sysdate,'yyyyMMddHH24miss')||lpad(s1.nextval,3,'0') 时间与补零序列号 from dual;
    4. 序列的删除        drop sequence 序列名称;
相关文章
相关标签/搜索