Oracle Sequence之深入浅出

这里介绍该Oracle Sequence的owner,或者有ALTER ANY Sequence 权
首页 新闻资讯 行业资讯 Oracle Sequence之深入浅出

Oracle有很多值得学习的地方,这里我们主要介绍Oracle Sequence,包括介绍Alter Sequence的例子等方面。第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前Sequence的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次 Sequence的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?

如果指定CACHE值,Oracle就可以预先在内存里面放置一些Sequence,这样存取的快些。cache里面的取完后,Oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的Sequence就会丢失. 所以可以在create Sequence的时候用nocache防止这种情况。

Alter Sequence

你或者是该Oracle Sequence的owner,或者有ALTER ANY Sequence 权限才能改动Sequence. 可以alter除start至以外的所有Oracle Sequence参数.如果想要改变start值,必须 drop Sequence 再 re-create.

Alter Sequence 的例子

复制

ALTER SEQUENCE emp_sequence  INCREMENT BY 10  MAXvalue 10000  CYCLE -- 到10000后从头开始  NOCACHE ;
  • 1.

  • 2.

  • 3.

  • 4.

  • 5.

影响Oracle Sequence的初始化参数:Sequence_CACHE_ENTRIES =设置能同时被cache的Sequence数目。

可以很简单的Drop Sequence

复制

create sequence SEQ_ID  minvalue 1  maxvalue 99999999  start with 1  increment by 1  nocache  order;
  • 1.

  • 2.

  • 3.

  • 4.

  • 5.

  • 6.

  • 7.

建解发器代码为:

复制

createorreplacetriggertri_test_id  beforeinsertonS_Depart--S_Depart是表名  foreachrow  declare  nextidnumber;  begin  IF:new.DepartIdISNULLor:new.DepartId=0THEN--DepartId是列名  selectSEQ_ID.nextval--SEQ_ID正是刚才创建的  intonextid  fromsys.dual;  :new.DepartId:=nextid;  endif;  endtri_test_id;
  • 1.

  • 2.

  • 3.

  • 4.

  • 5.

  • 6.

  • 7.

  • 8.

  • 9.

  • 10.

  • 11.

  • 12.

  • 13.

OK,上面的代码就可以实现自动递增的功能了。

【编辑推荐】

  1. 详谈Oracle对象特权说明

  2. Oracle系统特权部分介绍

  3. 最常见的Oracle密码验证

  4. 简单探讨Oracle介质恢复

  5. 完全干掉Oracle死锁进程

16    2009-11-18 13:30:37    Oracle Sequence