SQL 序列
来源:互联网 发布:mysql 拼接字符串 编辑:程序博客网 时间:2024/06/01 23:29
有时候 需要一个字段
CREATE SEQUENCE SUGGEST_SEQUENCE
MINVALUE 1
MAXVALUE 99999999999
START WITH 100
INCREMENT BY 1
NOCYCLE
CACHE 20
ORDER ;
//
注释:
MINVALUE 1 --最小值
MAXVALUE 99999999999 --最大值
START WITH 100 --起始数值
INCREMENT BY 1 --每次增加1
NOCYCLE --一直累加不循环
CACHE 20 --缓存
ORDER ;
还有一些其他参数,比如:
NOMAXVALUE --无最大值
NOCACHE --不设置缓存
如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。
.使用序列
定义好SEQUENCE,你就可以用CURRVAL,NEXTVAL
CURRVAL=返回 SEQUENCE的当前值
NEXTVAL=增加SEQUENCE的值,然后返回 SEQUENCE 值
EXAMPLE:
CUX_DEMO_SEQUENCE.CURRVAL
CUX_DEMO_SEQUENCE.NEXTVAL
可以使用SEQUENCE的地方:
- 不包含子查询、snapshot、VIEW的 SELECT 语句
- INSERT语句的子查询中
- NSERT语句的VALUES中
- UPDATE 的 SET中
可以看如下例子:
INSERT INTO CUX_DEMO_TABLE VALUES
(CUX_DEMO_SEQUENCE.NEXTVAL, 123 , 'IBAD' , 'MARK' ,'Y');
SELECT CUX_DEMO_SEQUENCE.CURRVAL FROM DUAL;
注意:
第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENTBY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。
3. 修改序列 ALTER SEQUENCE
你或者是该SEQUENCE的owner,或者有ALTER ANY SEQUENCE 权限才能改动SEQUENCE. 可以alter除start至以外的所有SEQUENCE参数.如果想要改变start值,必须 DROP SEQUENCE 再 重新创建SEQUENCE .
Alter SEQUENCE
ALTER SEQUENCE CUX_DEMO_SEQUENCE
INCREMENT BY 10
MAXVALUE 10000
CYCLE -- 到10000后从头开始
NOCACHE ;
影响SEQUENCE的初始化参数:
SEQUENCE_CACHE_ENTRIES =设置能同时被cache的SEQUENCE数目。
4.删除序列 DROP SEQUENCE
可以很简单的Drop SEQUENCE
DROP SEQUENCE CUX_DEMO_SEQUENCE;
- sql 序列
- SQL 序列
- SQL 序列
- Sql 序列
- oracle sql 序列
- SQL之序列
- SQL视图、序列、索引
- SQL主鍵:日期+序列
- oracle sql 序列 sequence
- SQL语句如何调用序列
- sql server实现oracle序列
- oracle中SQL修改序列
- SQL-Oracle08sql序列和同义词
- MS Sql Server 伪序列
- sql ORACLE(七):视图、序列
- SQL Server 生成时间序列
- oralce 序列创建的sql
- PL/SQL创建表序列
- python random模块
- Jenkins Maven打包出错异常的解决方法
- raid 2.0的理解
- java.policy 文件格式及使用方法
- Matlab GUI设计笔记
- SQL 序列
- String转换为json对
- 在开机的时候,执行想要的 shell script
- Rich Media(富媒体)媒体的定义
- UVA 1160 - X-Plosives 即LA3644 并查集判断是否存在环
- 在modelsim里仿真用ALTERA的IP core 生成的RAM/ROM模块
- kindeditor在dialog弹出框中无法获得焦点
- C++难点(1)——C++中的未定义行为
- struts-2.3.12引入json包struts2-json-plugin-2.3.12,断网时报错