`
wlh269
  • 浏览: 446716 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

在Oracle下实现主键自增(触发器)

阅读更多
最近做某个系统需要使用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,…); 

    
SQL >create sequence autoID increment by 1 start with 1 maxvalue 999999 cycle; 

  
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操作的时候,使表中主键值自动增加
。其实现步骤可参照如下例子。
drop table book;
--创建表   
create table book(    
   bookId varchar2(4) primary key,
   name varchar2(20)      
);
--创建序列   
create sequence book_seq start with 1 increment by 1; 

--创建触发器   
create or replace trigger book_trigger    
before insert on book    
for each row    
begin    
select book_seq.nextval into :new.bookId from dual;   
end ;
--添加数据   
insert into book(name)  values ('cc'); 
insert into book(name)  values ('dd');

commit;





查询数据:
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的值。
分享到:
评论
2 楼 TenAclock 2011-11-02  
book表的id类型设置的不合适(在oracle10g上测试),
引用


drop table book;  
--创建表     
create table book(      
   bookId varchar2(4) primary key,  
   name varchar2(20)        
);  


应该是:

drop table book;  
--创建表     
create table book(      
   bookId int primary key,  
   name varchar2(20)        
);
1 楼 caowei=root 2011-06-16  
执行结果是这样的

  2  before insert on book
  3  for each row
  4  begin
  5  select book_seq.nextval into :new.bookId from dual;
  6  end ;
  7  --添加数据
  8  insert into book(name)  values ('cc');
  9  insert into book(name)  values ('dd');
10 
11  commit;

12 
完全都不能执行完

相关推荐

    Oracle创建主键自增表(sql语句实现)及触发器应用

    主键自增在插入数据的时候是很实用的,可以获取并操作返回的插入记录的ID,接下来介绍Oracle如何创建主键自增表,感兴趣的你可以了解下,就当是巩固知识,希望此文对你有所帮助

    Oracle主键自增的办法

    用于Oracle的主键进行自增的办法,有触发器 和序列机制

    创建oracle数据库中表的主键和自增

    在oracle中可以利用触发器创建自增,从而完成我们像在sql server与mysql中定义的主键自增的功能。从而方便我们的开发

    Navicat Premium中Oracle创建主键自增的方法

    到此这篇关于Navicat Premium中Oracle创建主键自增的方法的文章就介绍到这了,更多相关Navicat Premium主键自增内容请搜索软件开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件开发网!

    如何实现Oracle自增,序列,触发器都有

    如何实现Oracle主键自增,通过写sequence和触发器,很全面,绝对帮你解决问题

    oracle主键自增

    oracle 数据库主键自增脚本 --第一步,创建表 --第二步,创建自增序列 --第三步,创建触发器

    oracle数据库主键自增并且返回主键值

    1.1、直接在PLSQL中设置 1.2、命令创建 create sequence seq_users ##创建序列seq_users increment by 1 ## 步长,每次加1 start with 1 ##从1开始 minvalue 1 ##最小值 maxvalue 9999999 ##最大值 order ##确保...

    Oracle数据库中创建自增主键的实例教程

    在设计数据库表的时候发现Oracle没有自增主键的设置,Google了解到Oracle本身并不支持自增主键,需要通过序列(Sequence)和触发器(Trigger)实现。 创建表Student Create Table Student( id number(12) primary ...

    oracle主键自动增长

    oracle数据库中主键属性没有自增长,所以只能自己写程序来实现,用序列与触发器,可以解决这个 问题

    oracle设置主键自动增长

    oracle设置主键自动增长 首先,你要有一张表! 然后,你需要一个自定义的sequence  以上代码完成了一个序列(sequence)的建立过程,名称为emp_sequence,范围是从1开始到无限大(无限大的程度是由你机器决定的),nocycle...

    Oracle在表上建立自增字段的方法

    本方法为使用SEQUENCE(序列)  例如有表temp_test结构为:  create table TEMP_TEST  (  id number,  nm varchar(10),  primary key(id) //...  2、在表temp_test上建立触发器如下  CREATE OR REPL

    Oracle数据库表序列ID自增生成器

    Oracle数据库表序列ID自增生成器的功能是为数据库中的表添加序列和触发器,以便使数据表的主键ID能够随着记录的增加而自动增加。

    oracle 复习资料

    oracle 复习资料,包括表空间,临时表空间,表,增删查改,各种约束(唯一,主键,外键,自增,默认等)存储过程,触发器的等

    sql总结.doc

    1.配合sequence实现自增(oracle) 2.提供审计和日志记录 3.写复杂的业务逻辑代码 (4)触发器的优缺点 优点: 1.实现级联更改 2.能过实现比check更严格的约束,与CHECK 约束不同,触发器可以引用其它表中的数据。通过...

    Hibernate注解

    * 8.seqhilo 通过hilo算法实现,但是主键历史保存在Sequence中,适用于支持Sequence的数据库,如Orcale(比较少用) * 例:@GeneratedValue(generator = "paymentableGenerator") * @GenericGenerator(name = ...

    mysql数据库的基本操作语法

    主键自增可以不插入,所以用null代替 指定列 insert into temp(name, age) values(‘jack’, 22); 在表面后面带括号,括号中写列名,values中写指定列名的值即可。当省略列名就表示插入全部数据, 注意插入值的...

Global site tag (gtag.js) - Google Analytics