Oracle有很多值得学习的地方,这里我们主要介绍Oracle Sequence,包括介绍Alter Sequence的例子等方面。第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前Sequence的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次 Sequence的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于做网站、成都网站建设、长泰网络推广、重庆小程序开发、长泰网络营销、长泰企业策划、长泰品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供长泰建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
如果指定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 ;
影响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;
建解发器代码为:
- 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;
OK,上面的代码就可以实现自动递增的功能了。
【编辑推荐】
文章标题:OracleSequence之深入浅出
链接分享:http://www.gawzjz.com/qtweb/news17/166367.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联