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;
oracle序列
       <2> 固定格式的查询----位数补零          
select lpad(s1.nextval,3,'0') 补零序列号 from dual;
oracle序列
       <3> 当前时间与自增序列结合.         
select to_char(sysdate,'yyyyMMddHH24miss')||lpad(s1.nextval,3,'0') 时间与补零序列号 from dual;
oracle序列
    4. 序列的删除
       drop sequence 序列名称;

你可能感兴趣的:(oracle,序列,应用)