Oracle之Sequence
来源:互联网 发布:linux查看打开文件数 编辑:程序博客网 时间:2024/05/22 06:44
在Oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。
Create Sequence
你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,
CREATE SEQUENCE emp_sequence INCREMENT BY 1 -- 递增1 START WITH 1 -- 从1开始计数 NOMAXVALUE -- 不设置最大值 NOCYCLE -- 不循环 CACHE 10; -- 缓存10个
一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL
CURRVAL=返回 sequence的当前值
NEXTVAL=增加sequence的值,然后返回 sequence 值
比如:
emp_sequence.CURRVAL
emp_sequence.NEXTVAL
可以使用sequence的地方:
- 不包含子查询、snapshot、VIEW的 SELECT 语句
- INSERT语句的子查询中
- NSERT语句的VALUES中
- UPDATE 的 SET中
可以看如下例子:
INSERT INTO emp VALUES (empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);
SELECT empseq.currval FROM DUAL;
但是要注意的是:
第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?
如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。
笔记摘自网络,方便以后查阅
补充:java读取数据库序列时不能用int,可以用long
- oracle之sequence
- ORACLE之SEQUENCE
- oracle 之sequence
- Oracle之Sequence
- Oracle Database之序列(Sequence)
- Oracle之Sequence(序列)
- Oracle 之 SEQUENCE 简单应用
- 【oracle】揭开oracle神秘面纱之Sequence
- Oracle、DB2、PostgreSQL之Sequence总结
- Oracle之constraint/index/view/sequence/grant
- 【Oracle学习】之 序列(Sequence)
- Oracle Sequence
- oracle Sequence
- Oracle sequence
- oracle sequence
- ORACLE SEQUENCE
- Oracle sequence
- ORACLE SEQUENCE
- thrift安装过程报错处理
- input子系统二 驱动层input设备注册
- Android 请求webservice
- Gradle下载及环境配置
- PM2的安装和使用简介
- Oracle之Sequence
- Mongodb Linux上安装配置
- linux0.11中head.s分析
- 什么是广播、组播、单播、多播、公播、直播
- 项目导入环信easeUI遇到的坑
- Oracle大数据库批量导入,引用Oracle.DataAccess
- CUDA By Examples 2
- Java遍历Properties的所有的元素,四种方法详细总结的代码实例
- 多个viewpager可能产生的问题