`
ccii
  • 浏览: 54957 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Oracle序列

    博客分类:
  • DB
阅读更多
1. 序列简介
  序列是Oracle提供的用于产生系列唯一数字的数据库对象。使用序列可以实现自动产生主键值。序列也可以在多用户并发环境中使用,为所有用户生成不重复的顺序数字,而且不需要任何额外的I/O开销。

2. 创建序列
语法:
CREATE SEQUENCE 序列名
[START WITH 开始值]
[INCREMENT BY 增量]
[MINVALUE 最小值 | NOMINVALUE]
[MAXVALUE 最大值 | NOMAXVALUE]
[CACHE 缓存 | NOCACHE]
[CYCLE | NOCYCLE]
[ORDER | NOORDER]

说明:
[START WITH 开始值]:指定序列的开始位置,默认情况下,递增序列的起始值为MINVALUE,递减序列的超值为MAXVALUE。
[INCREMENT BY 增量]:指定序列的增量,该参数为正数时生成一个递增序列,为负数则生成一个递减序列,默认值主1。
[CACHE 缓存 | NOCACHE]:指定是否产生序列号预分配,并存储在内存中。如数据库突然关闭,使得CACHE中的序列号丢失而出现跳号现象。
[CYCLE | NOCYCLE]:用来指定当序列达到MAXVALUE或MINVALUE时,是否可复位并继续下去。CYCLE达到极限时生成的下一个数据将分别是MINVALUE或MAXVALUE;如果是NOCYCLE,则达到极限并试图获取下一个值时将返回一个错误。
[ORDER | NOORDER]:指定是否保证生成的序列值是按顺序生成的

示例:
create sequence SEQ_BANK_ID
start with 1
increment by 1
minvalue 1
maxvalue 99999999
cache 100;

使用:
insert into BANK values(SEQ_BANK_ID.nextval, '招商银行'); //nextval伪列,返回序列生成的下一个值
select SEQ_BANK_ID.currval from dual; //currval伪列,返回序列的当前值

3. 修改序列
    除了序列的起始值以外其它定义序列的任何子句和参数都可以进行修改。如果要修改序列的起始值,则只能先删除该序列,然后重建该序列。对序列修改后,缓存中保存的序列值将全部丢失。
例:
alter sequence SEQ_BANK_ID increment by 2; //将序列增量修改为2

4. 删除序列
语法:drop sequence SEQ_BANK_ID;

0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics