在许多的数据表之中都存在一种称为自动增长列的操作,但是在 Oracle 之中,这种自动增长
列并不是自动控制的, 而是需要用户手工的控制,这样做主要是为了开发方便,
创建序列的语法如下:
create sequence sequence_name
[{minvalue n | NOMINVALUE}]
[{maxvalue n | NOMAXVALUE}]
[start with n]
[increment by n]
[{CYCLE | NOCYCLE}]
[{CACHE n | NOCACHE}];
创建序列
CREATE SEQUENCE my_seq start with 1 increment by 1;
当一个序列创建完之后,可以通过以下两种方式访问序列:
- 序列名称.nextval:让序列增长到下一个内容;
- 序列名称.currval:取得当前序列的内容;
SELECT my_seq.currval from dual;
-
在 Oracle 之中, 如果想要操作 currval,则首先必须先使用 nextval;
SELECT my_seq.nextval from dual; SELECT my_seq.currval from dual;
-
序列一般都作为主键使用,例如,下面定义一张表:
DROP TABLE mvtab PURGE; CREATE TABLE mytab( id number PRIMARY KEY, name varchar2(50) NOT NULL )
-
现在向 mvtab 表中增加数据:
INSERT INTO mytab(id,name) VALUES(my_seq.nextval,’ 张晓倩’);