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

news/2024/7/3 21:12:35

利用序列产生主键值。 

序列(Sequence)是一种可以被多个用户使用的用于产生一系列唯一数字的数据库对象。序列定义存储在数据字典中,通过提供唯一数值的顺序表来简化程序设计工作,可以使用序列自动产生主键的键值。当一个序列第一次被查询调用时,它将返回一个预定值。在随后的每次查询中,序列将产生一个按指定的增量增长的值。序列可以循环,或者是连续增加的,直到指定的最大值为止。 
创建序列语法如下:create sequence [模式]序列名称[start with 起始数字] [increment by 增量][maxvalue 最大值|nomaxvalue][minvalue 最小值|nominva lue][cycle|nocuyle][cache 数目|nocache][order|noorder]。 

通过序列起始数字、最大值、最小值和增量值可以确定序列是增序还是减序,每次增或减的多少。Nocyle选项用于确定在序列达到最大值(增序列)或最小值(减序列)之后不能再产生更多的值,用以防止序列回转。 

在Oracle数据库中创建序列,在使用sql语句向数据库中写入数据的时候,利用序列产生的唯一值,实现表中主键值自增。例如: 

  1. SQL>create table tablename    
  2.   
  3.     (id number notnull,…);
  4.   
  5.        
  6. SQL >create sequence autoID increment by 1 start with 1 maxvalue 999999 cycle;  
  7.   
  8.      
  9. 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事件发生之前采取行动。 

创建触发器的语法如下:

  1. create[or replace]trigger 触发器名称    
  2.   
  3. {before|after|instead of}激发触发事件    
  4.   
  5. referencing_clause    
  6.   
  7. [WHEN trigger_condition]    
  8.   
  9. [FOR EACH ROW]   

referencing_clause用来引用正在处于修改状态下的行中的数据,如果在WHEN子句中指定trigger_condition的话,则首先对该条件求值。触发器主体只有在该条件为真值时才运行。利用触发器与序列相结合,可以实现在进行DML操作的时候,使表中主键值自动增加。其实现步骤可参照如下例子。

 

  1. drop table book;   
  2. --创建表      
  3. create table book(       
  4.    bookId varchar2(4) primary key,   
  5.    name varchar2(20)         
  6. );   
  7. --创建序列      
  8. create sequence book_seq start with 1 increment by 1;    
  9.   
  10. --创建触发器      
  11. create or replace trigger book_trigger       
  12. before insert on book       
  13. for each row       
  14. begin       
  15. select book_seq.nextval into :new.bookId from dual;      
  16. end ;   
  17. --添加数据      
  18. insert into book(name)  values ('cc');    
  19. insert into book(name)  values ('dd');   
  20.   
  21. commit;  

 

 

查询数据:select * from book; 

当需要对book数据库表中的主键值进行写值时,便可以使用sql语句利用序列+触发器实现主键值自动增加.

 

 

REFS:http://blog.csdn.net/java3344520/article/details/4907591


http://www.niftyadmin.cn/n/4235222.html

相关文章

(转)SqlServer调用OPENQUERY函数远程执行增删改查

由于业务需求,我的SqlServer数据库通过MySQL的ODBC驱动连接了一个远程MySQL数据库,在SqlServer上要怎么远程执行MySQL命令呢,经过一番百度,将练习内容整理如下 /* OPENQUERY函数,远程执行数据库增删改查 关于OPENQ…

INT 10H功能介绍

INT 10H 是由 BIOS 对屏幕及显示器所提供的服务程序,而后倚天公司针对倚天中文提供了许多服务程序,这些服务程序也加挂在 INT 10H 内。使用 INT 10H 中断服务程序时,先指定 AH 寄存器为下表编号其中之一,该编号表示欲调用的功用&a…

SQL Server中的limit

在mysql中可以直接使用limit,在sql server中则不行,需要使用TOP,例如top 10 转载于:https://blog.51cto.com/bbtao/922467

更新的想法

全部更新的话,可以query-copy-delete-insert(查询DB记录,将新的非null{保持有DB的隐藏字段值}拷贝过来,删除DB的,insert合并后的记录--如果主键是数据库自动生成的会冲突,因为待插的记录里有主键)。 若hibernate&#…

图解虚拟机VMware服务自动启动

昨天是在VMware中使用crontab时间排程表在晚上12点定时关机,现在说说如何实现虚拟机开机自动启动,让cacti在centos的虚拟机随主机地起启动,可以说是实现公司服务器正常运行的一个不可或缺的环节。停电了机器重启有时不可能人不在或不记得了监…

智能补货 (在途、现有库存、安全库存) 的思路

按我的那个,在途库存就查我新建的表need_num字段。按他那个,多个调度单里的在途库存加起来(可以查在途SQL里根据门店、SKU分组,求出在途的和)作为一个整体在途,加现有的库存若小于安全则插入我的表里表示调…

SQL Server 2008与Oracle Database 11g相比较

数据仓库魔力象限 SQL Server是位于甘特的数据仓库魔力象限领导者象限。甘特强调SQL Server在数据仓库方面的使用越来越多,Microsoft提供了很高的性价比,SQL Server的升级并不需要很多工作量,而且Microsoft的全球支持是非常广泛的。 甘特批评…

left join 过滤条件要另写where

如图,如果想过滤条件必须在后面加where,如果跟着on后面加and ,结果集不会变、达不到过滤目的