Oracle 中的自动增长字段

环境:PLSQL Developer 7.1.5 Oracle 11.2.0

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

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

  1. CREATE SEQUENCE sequence_name
  2. INCREMENT BY step
  3. START WITH startvalue;

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

  1. sequence_name.CURRVAL
  2. sequence_name.NEXTVAL

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

DROP SEQUENCE sequence_name;

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

  1. CREATE SEQUENCE seq_PersonId
  2. MINVALUE 0
  3. INCREMENT BY 1
  4. START WITH 0;

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

然后创建T_Person表:

  1. CREATE TABLE T_Person
  2. (
  3. FId NUMBER (10) PRIMARY KEY,
  4. FName VARCHAR2(20),
  5. FAge NUMBER (10)
  6. );

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

  1. INSERT INTO T_Person(FId,FName,FAge)
  2. VALUES(seq_PersonId.NEXTVAL,‘Tom‘,18);
  3. INSERT INTO T_Person(FId,FName,FAge)
  4. VALUES(seq_PersonId.NEXTVAL,‘Jim‘,81);
  5. INSERT INTO T_Person(FId,FName,FAge)
  6. 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. BEFORE INSERT ON T_Person
  3. FOR EACH ROW
  4. DECLARE
  5. BEGIN
  6. SELECT seq_PersonId.NEXTVALINTO:NEW.FID FROM DUAL;
  7. END trigger_personIdAutoInc;

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

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

  1. INSERT INTO T_Person(FName,FAge)
  2. VALUES(‘Wow‘,22);
  3. INSERT INTO T_Person(FName,FAge)
  4. VALUES(‘Herry‘,28);
  5. INSERT INTO T_Person(FName,FAge)
  6. 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. DROP SEQUENCE seq_PersonId;
时间: 2024-10-18 01:13:00

Oracle 中的自动增长字段的相关文章

在oracle中创建自动增长字段

参考http://www.cnblogs.com/jerrmy/archive/2013/03/13/2958352.html oracle在创建表时和其他的数据库有点不一样,如SQL SERVER可以在int类型的字段后加上identity(1,1),该字段就会从1开始,按照+1的方式自增,将这个字段设置为主键,有利于我们进行数据的插入操作.MySql中可以使用"auto_increment"即可.但是oracle有点麻烦,需要使用序列和触发器达到目的. 首先我们创建一个员工表. c

oracle中的自动增长

create table test( id int not null primary key, name varchar2(20), sex int) ; create sequence t ->创建squence,命名为t minvalue 1 ->最小值 maxvalue 100000 ->最大值 start with 1 ->从1开始 increment by 1 ->增长比例 nocache ->增长池,为了提高效率,可以设置为 cache 10 ; inser

程序员的SQL经典笔记1_自动增长字段

自动增长字段在设计数据库的时候,有时需要表的某个字段是自动增长的,最常使用自动增长字段的就是表的主键,使用自动增长字段可以简化主键的生成.不同的DBMS中自动增长字段的实现机制也有不同,下面分别介绍. MYSQL 中设定一个字段为自动增长字段非常简单,只要在表定义中指定字段为AUTO_INCREMENT即可.例子: create table t_student ( t_id int primary key auto_increment, t_name varchar(50), t_age int

[转载]C#中使用ADO.NET连接SQL Server数据库,自动增长字段用作主键,处理事务时的基本方法

问题描述: 假设在数据库中存在以下两张数据表: User表,存放用户的基本信息,基本结构如下所示:   类型 说明 ID_User int 自动增长字段,用作该表的主键 UserName varchar   UserDepart表,存放用户所拥有的部门(我们假设一个用户拥有多个部门,虽然听起来有点别扭,此处仅作示例,可以理解为一个用户拥有多个职位等等),该表的基本结构如下所示:   类型 说明 ID_UserDepart int 自动增长字段,用作该表的主键 ID_User int 用户编号 I

Mysql,SqlServer,Oracle主键自动增长的设置

1.把主键定义为自动增长标识符类型 MySql 在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值.例如:   customers(id  auto_increment    , name (  customers(name)  id  customers; 以上sql语句先创建了customers表,然后插入两条记录,在插入时仅仅设定了name字段的值.最后查询表中id字段,查询结果为: 由此可见,一旦把id设为auto_increment类型,mys

触发器_实现ORACEL自动增长字段

实现XX表的字段code,为自动增长字段? 1.创建一个sequence,如图: 输入如下数据: S_COUNTRY为sequence名称 2.创建一个触发器,目的是在插入数据之前插入自动增长的数字,创建触发器 然后填写代码 create or replace trigger t_carmessage before insert on tb_carmessage for each row declare -- local variables here begin select S_COUNTRY

对于Oracle中Number类型的字段映射成Java中的具体类型的问题

我在Oracle中给一个用户Id字段设置为Number类型,使用JDBC在完成ORM的时候,以为其可以自动转换为Integer,因为我的POJO类id舒心实用的就是Integer.但事实是,我在测试的时候,发现所有的用户id全为null,还在奇怪明明数据库中id是有值的,为什么取不到? 原因在于Oracle的Number类型映射为Java类型中的 java.math.BigDecimal (不可变的.任意精度的有符号十进制数)类型,并不是我简单认为的 Integer ,还会报一个错误: 就是说B

oracle中的自动存储系统(ASM)

一.     ASM(自动存储管理)的来由: ASM是Oracle 10g R2中为了简化Oracle数据库的管理而推出来的一项新功能,这是Oracle自己提供的卷管理器,主要用于替代操作系统所提供的LVM,它不仅支持单实例,同时对RAC的支持也是非常好.ASM可以自动管理磁盘组并提供有效的数据冗余功能.使用ASM(自动存储管理)后,数据库管理员不再需要对ORACLE中成千上万的数据文件进行管理和分类,从而简化了DBA的工作量,可以使得工作效率大大提高. 二.     什么是ASM ASM它提供

Oracle中创建自增字段方法

oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现. 下面给大家讲个例子: 1.在Oracle中创建一个表: 1.创建一个表 create table t_client (id number(4) primary key, pid number(4) not null, name varchar2(30) not null, client_id varchar2(10), client_level char(3), bank_acc