`

oracle 自增长主键

阅读更多


首先,你要有一张表!

CREATE TABLE example(

ID Number(4) NOT NULL PRIMARY KEY,

NAME VARCHAR(25),

PHONE VARCHAR(10),

ADDRESS VARCHAR(50));

如果对于以上的建表语句还有疑问的话,建议您不要继续了!有那么些时间您还不如去看看金庸读读琼瑶!

然后,你需要一个自定义的sequence

CREATE SEQUENCE emp_sequence

INCREMENT BY 1 -- 每次加几个

START WITH 1 -- 从1开始计数

NOMAXVALUE -- 不设置最大值

NOCYCLE -- 一直累加,不循环

NOCACHE -- 不建缓冲区

以上代码完成了一个序列(sequence)的建立过程,名称为emp_sequence,范围是从1开始到无限大(无限大的程度是由你机器决定的),nocycle 是决定不循环,如果你设置了最大值那么你可以用cycle 会使seq到最大之后循环.对于nocache顺便说一下如果你给出了cache值那么系统将自动读取你的cache值大小个seq

,这样在反复操作时会加快运行速度,但如果遭遇意外情况如当机了或oracle死了,则下次取出的seq值将和上次的不连贯.(如果连不连贯无所谓建议用cache,因为时间就是金钱呀)

书接上文,你只有了表和序列还不够,还需要一个触发器来执行它!代码如下:

CREATE TRIGGER "触发器名称" BEFORE

INSERT ON example FOR EACH ROW WHEN (new.id is null)

begin

select emp_sequence.nextval into: new.id from dual;

end;

打完收工!下面你就试试插入数据吧!

INSERT INTO example(Name,phone,address) Values(''Cao'',''56498543'',''Heibei'');





=============================================================

ORACLE SEQUENCE的简单介绍(自增长字段)- -







from:http://ub1010.51.net/BBS/user_file/2002-04-10/1018438701.htm



在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。

1、CreateSequence

你首先要有CREATESEQUENCE或者CREATEANYSEQUENCE权限,

CREATESEQUENCEemp_sequence

INCREMENTBY1--每次加几个

STARTWITH1--从1开始计数

NOMAXVALUE--不设置最大值

NOCYCLE--一直累加,不循环

CACHE10;



一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL

CURRVAL=返回sequence的当前值

NEXTVAL=增加sequence的值,然后返回sequence值

比如:

emp_sequence.CURRVAL

emp_sequence.NEXTVAL



可以使用sequence的地方:

-不包含子查询、snapshot、VIEW的SELECT语句

-INSERT语句的子查询中

-NSERT语句的VALUES中

-UPDATE的SET中



可以看如下例子:

INSERTINTOempVALUES

(empseq.nextval,''LEWIS'',''CLERK'',7902,SYSDATE,1200,NULL,20);



SELECTempseq.currvalFROMDUAL;



但是要注意的是:

-第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENTBY值,然后返回增加后的值。CURRVAL总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?



-如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。使用cache或许会跳号,比如数据库突然不正常down掉(shutdownabort),cache中的sequence就会丢失.所以可以在createsequence的时候用nocache防止这种情况。



2、AlterSequence

你或者是该sequence的owner,或者有ALTERANYSEQUENCE权限才能改动sequence.可以alter除start至以外的所有sequence参数.如果想要改变start值,必须dropsequence再re-create.

Altersequence的例子

ALTERSEQUENCEemp_sequence

INCREMENTBY10

MAXVALUE10000

CYCLE--到10000后从头开始

NOCACHE;





影响Sequence的初始化参数:

SEQUENCE_CACHE_ENTRIES=设置能同时被cache的sequence数目。



可以很简单的DropSequence

DROPSEQUENCEorder_seq;





好吧,就到这里。





-------------------------------------------------------------

自增长及触发器:



如何在Oracle中实现类似自动增加ID的功能?

整理编辑:ChinaASP



我们经常在设计数据库的时候用一个系统自动分配的ID来作为我们的主键,但是在ORACLE中没有这样的



功能,我们可以通过采取以下的功能实现自动增加ID的功能

1.首先创建sequence

createsequenceseqmaxincrementby1

2.使用方法

selectseqmax.nextvalIDfromdual

就得到了一个ID

如果把这个语句放在触发器中,就可以实现和mssql的自动增加ID相同的功能!





-------------------------------------------------------------------------



###建表###



CREATETABLE"SPORTS"."LINEUP"("ID"NUMBERNOTNULL,"TYPE"

NUMBER(3)NOTNULL,"BODY"VARCHAR2(100)NOTNULL,"HITS"NUMBER(

10)DEFAULT0NOTNULL,PRIMARYKEY("ID"))

TABLESPACE"TS_SPORTS"



###建序列###



CREATESEQUENCE"SPORTS"."SPORTS_LINEUP_ID_SEQ"INCREMENTBY1

STARTWITH1MAXVALUE1.0E28MINVALUE1NOCYCLE

CACHE50NOORDER



###建自动更新的触发器###



CREATEORREPLACETRIGGER"SPORTS"."SPORTS_LINEUP_ID_TRIGGER"

BEFOREINSERT

ON"SPORTS"."LINEUP"

FOREACHROW

DECLARE

next_idNUMBER;

BEGIN

--Getthenextidnumberfromthesequence

SELECTsports_lineup_id_seq.NEXTVAL

INTOnext_id

FROMdual;



--Usethesequencenumberastheprimarykey

--fortherecordbeinginserted.

:new.id:=next_id;

END;



###建保护PRIMARYKEY的触发器###



CREATEORREPLACETRIGGER"SPORTS"."LINEUP_ID_UPDATE_TRIGGER"

BEFOREUPDATEOF"ID"ON"SPORTS"."LINEUP"

FOREACHROW

BEGIN

RAISE_APPLICATION_ERROR(-20000,

''sports_lineup_id_update_trigger:UpdatesoftheIDfield''

||''arenotallowed.'');

END

分享到:
评论

相关推荐

    oracle 自增长主键.doc

    以下是对Oracle自增长主键的详细解释: 首先,要创建一张包含自增长主键的表,你可以使用如下的SQL语句: ```sql CREATE TABLE example ( ID Number(4) NOT NULL PRIMARY KEY, NAME VARCHAR(25), PHONE VARCHAR...

    oracle触发器实现主键自动增长

    在Oracle数据库中,实现主键自动增长是一种常见的需求,尤其在设计高并发、大数据量的系统时,确保每个记录都有一个唯一且连续的标识符变得至关重要。本文将深入探讨如何利用Oracle触发器来实现这一功能,同时也会...

    oracle主键自动增长

    ### Oracle主键自动增长知识点详解 #### 一、Oracle序列(Sequence)的使用方法 在Oracle数据库中,并没有像MySQL那样的自动增长字段特性,因此在实际应用中,我们常常需要手动实现这一功能。序列(Sequence)是...

    java自动生成Oracle sequence管理类

    Oracle自增长主键自动生成类 public static int nextID String table { if table null return 1; table table toLowerCase ; String strKey table; if sequences containsKey strKey { ...

    oracle序列主键自增长

    本文将深入探讨Oracle序列主键自增长的工作原理、创建方法以及如何在表中应用。 **1. Oracle序列(Sequences)基础** Oracle序列是一个数据库对象,它可以生成一系列唯一的数字,这些数字可以被用作表的主键。序列...

    oracle设置主键自动增长

    ### Oracle 设置主键自动增长详解 #### 一、概述 在数据库设计中,为了方便管理和维护数据表,经常需要为主键设置自动增长的功能。Oracle 数据库提供了强大的工具和语法支持来实现这一需求。本文主要介绍如何在 ...

    powerdesigner创建oracle_数据库表,设置表主键列为自动增长

    #### 三、创建表及设置自动增长主键 **步骤1:创建表** 1. 打开PowerDesigner 12.5。 2. 在项目管理界面选择一个现有的或新建一个物理数据模型(PDM)项目。 3. 在物理数据模型中,通过“Table”工具绘制一个新的表...

    Oracle数据库创建表tuser设置主键自动增长

    在Oracle数据库中,创建一张包含自动增长主键的表是一项常见的需求。本文将详细介绍如何在Oracle环境中创建一个名为`tuser`的表,并实现其主键自动增长的功能。此外,还将介绍如何通过序列(sequence)来管理这个自动...

    oracle主键自动增长方法

    oracle创建表时主键自动增长方法 5 测试反复执行如下语句:insert into Test_Increase(Username) values('test')6 查看插入结果:userid username1 test2 test3 test4 test5 test6 test7 test8 test9 test

    oracle设置主外键即主键序列自动增长

    ### Oracle 设置主外键及主键序列自动增长 在Oracle数据库管理系统中,为了确保数据的一致性和完整性,经常需要设置主键(Primary Key)和外键(Foreign Key)。此外,为了方便管理和操作,通常还会使用序列...

    oracle自动增长列

    ### Oracle自动增长列知识点 在Oracle数据库中,实现自动增长列的功能主要依赖于`SEQUENCE`对象。通过创建一个序列(SEQUENCE),可以方便地为表中的某列自动生成唯一的值,这对于主键或者需要唯一标识符的场景非常...

    oracle设定自增长列

    总之,通过上述步骤,我们不仅创建了一个具有自增长主键的表,还通过序列和触发器的组合使用,确保了该主键能够自动递增,提供了一种高效且安全地管理表中记录唯一标识符的方法。这种方法在Oracle数据库中非常实用,...

    oracle自增长与临时表

    **一、Oracle自增长** 在Oracle中,没有像其他数据库系统(如MySQL)那样内置的自增长机制。但是,我们可以通过创建序列(Sequences)来实现类似的功能。序列是一种数据库对象,可以生成一系列的唯一数值,常用于...

    oracle中的sequence实现主键增长

    总的来说,Oracle中的Sequence提供了一种可靠且灵活的方式来生成序列号,适用于需要自动增长主键的场景。通过合理配置和使用,可以有效避免数据冲突,提高插入数据的效率。在设计数据库时,应根据具体业务需求来决定...

    OracleID自增长

    ### Oracle ID自增长实现方法详解 #### 一、引言 在使用Oracle数据库进行软件开发时,经常会遇到需要为表中的记录自动生成唯一标识符(ID)的需求。而在Oracle数据库中,与MySQL不同的是,它并没有提供直接的自...

    在hibernate中实现oracle的自动增长

    本文将深入探讨如何在Hibernate中实现Oracle数据库的自动增长特性,这一功能对于确保数据表中的主键唯一性至关重要。 ### Oracle数据库的自动增长机制 Oracle数据库提供了强大的序列(sequence)功能来支持自动增长...

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

    这不仅有助于确保数据的唯一性,还能简化开发过程中的某些环节,尤其是在需要自动增长的主键时。下面将详细介绍如何通过序列(Sequence)和触发器(Trigger)来实现在Oracle中创建自增的主键。 #### 序列(Sequence...

    oracle中用序列实现自动增长值

    在Oracle数据库系统中,与SQL Server中的`IDENTITY`特性类似,我们可以通过使用序列(Sequences)来实现字段的自动增长值。序列是一种特殊的数据库对象,它可以生成一系列有序的数值,通常用于为表的主键字段提供...

Global site tag (gtag.js) - Google Analytics