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;
分享到:
相关推荐
java通过Mysql实现类似oracle序列功能,
网上很多讲序列的文章,但是讲的不够详细,看了这个,秒懂 oracle的用法,内容包含使用场景全冲用法介绍
文档 里面包含了 mysql创建 oracle序列的脚本,数据库表、函数、使用案例 sql和截图 ,自带 根据步长和值长度,到数据最大时返回0;手册说明详细,表名字段都有解释,一看就懂
最近项目中要用oracle中的序列相关的内容,本人对oracle是小白一个,没办法只能在网上找相关的资源,还好,发现了一些,感觉挺实用的,就分享给大家了,该资源是oracle序列的创建、修改、以及删除的相关操作,有用例...
oracle序列主键自增长实现主键自动增长
详解Oracle序列和触发器的使用。。。。。。。。
Oracle序列创建及使用(txt文本),Oracle序列创建及使用(txt文本),Oracle序列创建及使用(txt文本)
oracle 中不用新建序列是实现重置序列(从1开始增长)
介绍了PL/SQL工具,导出oracle序列的方法以及步骤
文档 里面包含了 mysql创建 oracle序列的脚本,数据库表、函数、使用案例 sql和截图 ,自带 根据步长和值长度,到数据最大时返回0;手册说明详细,表名字段都有解释,一看就懂
NULL 博文链接:https://zzx0421.iteye.com/blog/335955
今天小编就为大家分享一篇关于MySQL实现类似Oracle序列的方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
oracle索引、序列和权限设置
序列的用法,第序列在数据库的用法和操作,详细阅读资料里面有详细介绍。
NULL 博文链接:https://chaoyi.iteye.com/blog/2146830
oracle 序列自增oracle
介绍sqlserver中创建类似于oracle中序列的过程,此例只是一个简单的模仿。
重置oracle序列从指定数字开始 代码如下: declare n number(10); v_startnum number(10):=10000001;–从多少开始 v_step number(10):=1;–步进 tsql varchar2(200); v_seqname varchar2(200):=’MIP_JF_SEQUENCE’;...
通过sql建立序列和触发器,完成oracle的主键id的自增长