码迷,mamicode.com
首页 > 数据库 > 详细

Oracle 中的自动增长字段

时间:2015-04-22 16:28:41      阅读:235      评论:0      收藏:0      [点我收藏+]

标签:

环境:PLSQL Developer 7.1.5 Oracle 11.2.0

 

Oracle 中不像MYSQLMSSQLServer中那样指定一个列为自动增长列的方式,不过在Oracle中可以通过SEQUENCE序列来实现自动增长字段。在OracleSEQUENCE被称为序列,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。

在使用SEQUENCE前需要首先定义一个SEQUENCE,定义SEQUENCE的语法如下:


  1. CREATE SEQUENCE sequence_name   

  2.   

  3. INCREMENT BY step   

  4.   

  5. START WITH startvalue;   

其中sequence_name为序列的名字,每个序列都必须有唯一的名字;startvalue参数值为起始数字,step参数值为步长,即每次自动增长时增加的值。一旦定义了SEQUENCE,你就可以用CURRVAL来取得SEQUENCE的当前值,也可以通过NEXTVAL来增加SEQUENCE,然后返回 新的SEQUENCE值。比如:


  1. sequence_name.CURRVAL   

  2.   

  3. sequence_name.NEXTVAL   

如果SEQUENCE不需要的话就可以将其删除:

DROP SEQUENCE sequence_name;

下面举一个使用SEQUENCE序列实现自动增长的例子。首先创建一个名称为seq_PersonId SEQUENCE

 

  1. CREATE SEQUENCE seq_PersonId   

  2.   

  3. MINVALUE 0  

  4.   

  5. INCREMENT BY 1   

  6.   

  7. START WITH 0;   

注:如果没加这句(MINVALUE 0),可能会出现这个错误(ORA-04006: START WITH不能小于 MINVALUE)。解决方法就是指定最小值。

然后创建T_Person表:


  1. CREATE TABLE T_Person   

  2.   

  3. (    

  4.   

  5. FId NUMBER (10) PRIMARY KEY,    

  6.   

  7. FName VARCHAR2(20),    

  8.   

  9. FAge NUMBER (10)   

  10.   

  11. );   

执行上面的SQL语句后就创建成功了T_Person表,然后执行下面的SQL语句向T_Person表中插入一些数据:


  1. INSERT INTO T_Person(FId,FName,FAge)   

  2.   

  3. VALUES(seq_PersonId.NEXTVAL,‘Tom‘,18);   

  4.   

  5.    

  6.   

  7. INSERT INTO T_Person(FId,FName,FAge)   

  8.   

  9. VALUES(seq_PersonId.NEXTVAL,‘Jim‘,81);   

  10.   

  11.    

  12.   

  13. INSERT INTO T_Person(FId,FName,FAge)   

  14.   

  15. VALUES(seq_PersonId.NEXTVAL,‘Kerry‘,33);   

注意这里的INSERT语句没有为FId字段设定任何值,因为DBMS会自动为FId字段设定值。执行完毕后查看T_Person表中的内容:

FID  FNAME  FAGE

1  Tom  18

2  Jim  81

3  Kerry  33

使用SEQUENCE实现自动增长字段的缺点是每次向表中插入记录的时候都要显式的到SEQUENCE中取得新的字段值,如果忘记了就会造成错误。为了解决这个问题,我们可以使用触发器来解决,创建一个T_Person表上的触发器:

  1. CREATE OR REPLACE TRIGGER trigger_personIdAutoInc   

  2.   

  3.    BEFORE INSERT ON T_Person   

  4.   

  5.    FOR EACH ROW    

  6.   

  7. DECLARE    

  8.   

  9. BEGIN    

  10.   

  11.    SELECT seq_PersonId.NEXTVALINTO:NEW.FID FROM DUAL;   

  12.   

  13. END trigger_personIdAutoInc;   

这个触发器在T_Person 中插入新记录之前触发,当触发器被触发后则从seq_PersonId中取道新的序列号然后设置给FID字段。

执行下面的SQL语句向T_Person表中插入一些数据:

  1. INSERT INTO T_Person(FName,FAge)   

  2.   

  3. VALUES(‘Wow‘,22);   

  4.   

  5.    

  6.   

  7. INSERT INTO T_Person(FName,FAge)   

  8.   

  9. VALUES(‘Herry‘,28);   

  10.   

  11.    

  12.   

  13. INSERT INTO T_Person(FName,FAge)   

  14.   

  15. VALUES(‘Gavin‘,36);   

注意在这个SQL语句中无需再为FId字段赋值。执行完毕后查看T_Person表中的内容:

FID  FNAME  FAGE

1  Tom  18

2  Jim  81

3  Kerry  33

4  Wow  22

5  Herry  28

7  Gavin  36

这个例子讲解完了,请删除T_Person表以及SEQUENCE

  1. DROP TABLE T_Person;   

  2.   

  3. DROP SEQUENCE seq_PersonId;  

Oracle 中的自动增长字段

标签:

原文地址:http://my.oschina.net/Sheamus/blog/405085

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!