当前位置:Gxlcms > 数据库问题 > oracle中的CURRVAL和NEXTVAL用法

oracle中的CURRVAL和NEXTVAL用法

时间:2021-07-01 10:21:17 帮助过:435人阅读

1 -- 每次加几个 START WITH 1 -- 从1开始计数 NOMAXVALUE -- 不设置最大值 NOCYCLE -- 一直累加,不循环 CACHE 10;


上面的语句则创建了一个INR_REQUIRMENT_SQUENCE序列

3.如何获取一个sequence的值?  

SELECT INR_REQUIRMENT_SQUENCE.CURRVAL FROM dual –获取当前的sequence的值, 

 

 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值, 然后返回增加后的值。CURRVAL 总是返回当前sequence的值,但是在第一次NEXTVAL 初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次sequence的值, 所以如果你在同一个语句里面使用多个NEXTVAL。

如图:

技术图片

 

4.可以在哪些地方使用Sequence?

不包含子查询、snapshot、VIEW的 SELECT 语句
INSERT语句的子查询中
NSERT语句的VALUES中
UPDATE 的 SET中
在实际开发中,比如一个表中的主键需要先得到主键ID,可以用NEXTVAL来获下一个取序列值,然后再进行其他操作。
5.如何删除Sequence? 

DROP sequence policy_id_seq; –policy_id_seq为sequence的名字,如果要改变sequence中的初始值,必须先删除序列号然后再进行创建。你或者是该sequence的owner,或者有ALTER ANY sequence权限才能改动sequence,直接用Alter语句进行sequence的更新。

oracle中的CURRVAL和NEXTVAL用法

标签:查询   多个   insert   create   Owner   rem   net   bsp   开发   

人气教程排行