最近做某个系统需要使用Oracle作为数据后台,之前使用SQL-Server和MySQL都特别习惯使用系统的字增功能,让一个数据字段,通常是ID作为主键实现自增,但是发现Oracle中创建向导中根本就没有这项功能。自己想的方法是采用触发器Trigger,或者更加复杂的专门创建一个数据表用来存储index。Baidu之后得到如下答案:
利用序列产生主键值。
序列(Sequence)是一种可以被多个用户使用的用于产生一系列唯一数字的数据库对象。序列定义存储在数据字典中,通过提供唯一数值的顺序表来简化程序设计工作,可以使用序列自动产生主键的键值。当一个序列第一次被查询调用时,它将返回一个预定值。在随后的每次查询中,序列将产生一个按指定的增量增长的值。序列可以循环,或者是连续增加的,直到指定的最大值为止。
创建序列语法如下:create sequence [模式]序列名称[start with 起始数字] [increment by 增量][maxvalue 最大值|nomaxvalue][minvalue 最小值|nominva lue][cycle|nocuyle][cache 数目|nocache][order|noorder]。
通过序列起始数字、最大值、最小值和增量值可以确定序列是增序还是减序,每次增或减的多少。Nocyle选项用于确定在序列达到最大值(增序列)或最小值(减序列)之后不能再产生更多的值,用以防止序列回转。
在Oracle数据库中创建序列,在使用sql语句向数据库中写入数据的时候,利用序列产生的唯一值,实现表中主键值自增。例如:
SQL>create table tablename
(id number notnull,…);
Table created
SQL >create sequence autoID increment by 1 start with 1 maxvalue 999999 cycle;
Sequence created
SQL >insert into tablename values(autoID.nextval,...);
多个用户可以共用一个序列,但它是针对所有的表,因此产生的序号对一个表而言产生的主键值唯一但是不连续。
使用触发器产生主键值。
在数据表中,有时候需要主键值自动增加,但在Oracle数据库中,没有象Mysql的Autoincrement一样自动增长的数据类型。在实现Oracle数据库字段自增功能时,利用DML触发器来完成。
触发器(trigger)是一些过程,当发生一个特定的数据库事件时就执行这些过程,可以使用触发器扩充引用的完整性。DML即数据操纵语言,用于让用户或程序员使用,实现对数据库中数据的操作。基本的数据操作分成两类四种:检索(查询)和更新(插入、删除、修改)。触发器类似于函数和过程,其在数据库中以独立身分存在。触发事件可以是对数据库表的DML(insert、update或delete)操作等。DML触发器是目前最广泛使用的一种触发器,即由DML语句激发的触发器,并有该语句决定DML触发器的类型。其触发事件包括insert(插入)、update(更新)和delete(删除)。无论哪种触发事件,都能为每种触发事件创建before触发器和after触发器。如可以在表上建立一个before insert 语句,表示在insert事件发生之前采取行动。
创建触发器的语法如下:
create[or replace]trigger 触发器名称
{before|after|instead of}激发触发事件
referencing_clause
[WHEN trigger_condition]
[FOR EACH ROW]
referencing_clause用来引用正在处于修改状态下的行中的数据,如果在WHEN子句中指定trigger_condition的话,则首先对该条件求值。触发器主体只有在该条件为真值时才运行。利用触发器与序列相结合,可以实现在进行DML操作的时候,使表中主键值自动增加。其实现步骤可参照如下例子。
1) 创建表
SQL>create table book(id number(10),a varchar2(10), primary key(id));
Table created
2)建序列
SQL>create sequence book _seq start with 1 increment by 1;
Sequence created
3)建自动更新的触发器
SQL> create or replace trigger book _trigger
2 before insert on book
3 for each row
4 begin
5 select book _seq.nextval into :new.id from dual;
6 end ;
7 /
Trigger created
完成以上步骤,我们就可以使用触发器完成在插入时,自动写入数据表主键ID值。
SQL> insert into book (a) values ('aa');
1 row inserted
SQL> insert into book (a) values ('bb');
1 row inserted
SQL> commit;
Commit complete
SQL> select * from book;
ID A
----------- ----------
1 aa
2 bb
在JSP页面中,当需要对book数据库表中的主键值进行写值时,便可以使用sql语句利用序列+触发器实现主键值自动增加。具体语句如下:
<% String sql="insert into book (a) values('aa' )";
stmt.executeUpdate(sql);%>
数据库表中便会自动生成ID的值。