Oracle Sequence之深入浅出
创始人
2024-06-12 02:31:31
0

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 的例子

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

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

可以很简单的Drop Sequence

  1. create sequence SEQ_ID  
  2. minvalue 1  
  3. maxvalue 99999999  
  4. start with 1  
  5. increment by 1  
  6. nocache  
  7. order; 

建解发器代码为:

  1. createorreplacetriggertri_test_id  
  2. beforeinsertonS_Depart--S_Depart是表名  
  3. foreachrow  
  4. declare  
  5. nextidnumber;  
  6. begin  
  7. IF:new.DepartIdISNULLor:new.DepartId=0THEN--DepartId是列名  
  8. selectSEQ_ID.nextval--SEQ_ID正是刚才创建的  
  9. intonextid  
  10. fromsys.dual;  
  11. :new.DepartId:=nextid;  
  12. endif;  
  13. endtri_test_id; 

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

【编辑推荐】

  1. 详谈Oracle对象特权说明
  2. Oracle系统特权部分介绍
  3. 最常见的Oracle密码验证
  4. 简单探讨Oracle介质恢复
  5. 完全干掉Oracle死锁进程

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...