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 序列名称;