转自:http://blog.csdn.net/gameloft9/article/details/20902805
一、概述
sequence是序列号的意思,每次取的时候它会自动增加。sequence与表没有从属关系,与表一样属于用户。 二、主要内容 1、Create Sequence语法 --首先用户要有CREATE SEQUENCE或者CREATE ANY SEQUENCE的权限。 CREATE SEQUENCE seqname [ INCREMENT increment ] [ MINVALUE minvalue ] [ MAXVALUE maxvalue ] [ START start ] [ CACHE cache ] [ CYCLE ][order]
seqname: 序列名 increment: 递增数,例如increment by 1就是递增1;increment by -1就是递减1。 minvalue: 序列最小值 maxvalue: 序列最大值,最大为27个9. start: 序列从哪个值开始,例如start with 200就是从200开始。 cache: 缓存序列个数,先取一部分序列值存入缓存,可以提高性能。缺点是发生系统故障后可能导致 序列号不连续。可以设置为nocache保证不会发生序列跳动。默认值是20。 cycle: 循环,到达最大值后,从最小值重新开始生成序列号。可以设置为nocycle表示累加不循环。 order: 保证按顺序申请。默认是noorder。ORDER 和 NOORDER 的区别表现在 并行服务 和独占服务之间 打个比方:双CPU对同一个oracle DB 中的 ABC sequence申请序号时, 这时就有两个请求A和B,假设A请求在前B在后, 现在ABC序列中的值为9. 如果添加了ORDER选项,那么一定是A请求到9, B请求到10.但如果没有添加此选项,则有可能B请求到9, A请求到10.order一般用于时间戳类型,对于主键则用处不大。 例子: CREATE SEQUENCE seq minvalue 1 --最小值 INCREMENT BY 1 --递增1 START WITH 1 --从1开始 NOMAXvalue --无最大值 NOCYCLE --不循环 CACHE 100; --缓存100个序列号
2、使用sequence 定义好sequence后,你就可以用currVal,nextVal取得值。 CurrVal:返回 sequence的当前值 NextVal:返回sequence的下一个值 select seq.currval from dual select seq.nextval from dual 3.在Sql语句中可以使用sequence的地方: (1)不包含子查询、snapshot、VIEW的 SELECT 语句 (2)INSERT语句的子查询中
(3)INSERT语句的values中 (4)UPDATE 的 SET中 例如: insert into student(id,name) values(seq.Nextval,'jack');
注意: 第一次NEXTVAL返回的是初始值,随后的NEXTVAL会返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则报如下错误: ORA-08002 序列currval尚未在会话中定义。
使用一次NEXTVAL会增加一次 SEQUENCE的值,所以如果你多次执行包含NEXTVAL的一条语句,其值就是不一样的。 3、修改sequence参数 拥有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence再create。 例: alter sequence SEQ maxvalue 9999999; alter sequence SEQ cache 10; 4、Drop Sequence DROP SEQUENCE seq;