Oracle sequence 序列

[size=medium][b]1.创建序列[/b][/size]

CREATE SEQUENCE sequence //创建序列名称
[INCREMENT BY n] //递增的序列值是n 如果n是正数就递增,如果是负数就递减 默认是1
[START WITH n] //开始的值,递增默认是minvalue 递减是maxvalue
[{MAXVALUE n | NOMAXVALUE}] //最大值 NOMAXVALUE没有最大值
[{MINVALUE n | NOMINVALUE}] //最小值 NOMINVALUE没有最小值
[{CYCLE | NOCYCLE}] //循环/不循环
[{CACHE n | NOCACHE}]//分配并存入到内存中
[ORDER | NOORDER];//保证序列产生的顺序和请求的顺序是否一致


实例:

-- Create sequence
create sequence S_XD_SHOP
minvalue 1
maxvalue 999999999
start with 81
increment by 1
cache 20;


[size=medium][b]2.更改序列命令[/b][/size]
ALTERSEQUENCE [user.]sequence_name
[INCREMENT BY n]
[MAXVALUE n| NOMAXVALUE ]
[MINVALUE n | NOMINVALUE];
修改序列可以:
修改未来序列值的增量。
设置或撤消最小值或最大值。
改变缓冲序列的数目。
指定序列号是否是有序。

[size=medium][b]3.删除序列命令[/b][/size]
DROP SEQUENCE [user.]sequence_name;
用于从数据库中删除一序列。

[size=medium][b]4.SQL中取序列号的用法:[/b][/size]

SELECT NCME_QUESTION_SEQ.nextval FROM dual --nextval 当前序列号的下一个值
SELECT NCME_QUESTION_SEQ.CURRVAL FROM dual --CURRVAL 当前序列号的值

[size=medium][b]5.使用目的[/b][/size]
通常用于生成数据库数据记录的自增长主键或序号的地方

[size=medium][color=red]注意点:[/color][/size]

[size=medium][color=blue][b]oracle 序列 的order选项[/b][/color][/size]
order保证序列产生的顺序和请求的顺序是一致的,在并行模式下如果A、B同时对序列请求那么先产生的序列号必然返回给先请求的用户。例如当前序列号为10,A先请求B后请求那么11一定返回给A,12给B,在noorder的情况下,有可能11给B,12给A。

[size=medium][color=blue][b]指定CACHE值[/b][/color][/size]
如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。
cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号,
比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失.
所以可以在create sequence的时候用nocache防止这种情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值