Oracle中的序列SEQUENCE详解 |
一、序列介绍Oracle的序列是一种数据库对象,主要作用是用来产生唯一值 。序列被创建以后可以通过数据字典找到序列对象,因此序列可以被多个对象共享 。 二、创建序列序列使用CREATE SEQUENCE语法进行创建: CREATE SEQUENCE sequence [INCREMENT BY n] [START WITH n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}];
例如: CREATE SEQUENCE invoice_seq INCREMENT BY 1 START WITH 1 MAXVALUE 9999999 NOCYCLE NOCACHE; 三、查询序列一旦序列被创建,序列的创建代码就被文本化在数据字典中,可以在user_objects数据字典中看到,如: SELECT object_name,object_id,object_type FROM user_objects WHERE object_name = 'INVOICE_SEQ'; 在user_sequences表中保存了序列明细信息: SELECT sequence_name, min_value, max_value, increment_by, last_number FROM user_sequences; 四、使用序列NEXTVAL和CURRVAL伪列
使用如下 : SELECT invoice_seq.CURRVAL,invoice_seq.NEXTVAL FROM DUAL; INSERT INTO invoice (invoice_id, vendor_id, invoice_number, invoice_total ) VALUES (invoice_seq.NEXTVAL, 10, 'INV' || invoice_seq.CURRVAL, 100 ); 可以在下面的上下文中使用NEXTVAL和CURRVAL:
不能再以下的上下文中使用NEXTVAL和CURRVAL:
另外要注意,ROLLBACK并不能使序列值回滚 。 五、修改序列如: ALTER SEQUENCE invoice_seq INCREMENT BY 2 MAXVALUE 10 NOCACHE NOCYCLE; 修改序列时,有如下几个限制:
六、删除序列DROP SEQUENCE invoice_seq; 七、创建自增序列1、创建一个序列 create sequence sq_recid minvalue 1 maxvalue 999999 increment by 1 start with 1 noCYCLE; 2、创建一个触发器 create or replace trigger trg_test before insert on test for each row begin select sq_recid.nextval into :new.ID from dual; end; alter trigger trg_test enable; 3、在C#中也可以手工插入序列到表中 string sql="insert into test(ID,otherCol)value (Sql_recid.nextval,***) retuing ID into :ID" 到此这篇关于Oracle序列SEQUENCE的文章就介绍到这了 。希望对大家的学习有所帮助,也希望大家多多支持 。 |