oracle创建序列(oracle创建序列号)

本篇文章给大家谈谈oracle创建序列,以及oracle创建序列号对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

如何给oracle中的表建一个序列

在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创建一个序列,让他一直显示五位怎么做,比如00001/00002/00003.......

我们经常会在在DB中创建序列:

-- Create sequence

create sequence COMMON_SEQ

minvalue 1

maxvalue 999999999

start with 1

increment by 1

cache 20

cycle;

我们的序列的最小值是从1开始,但是我们想让这种顺序取出来的序列的位数都一样,按照最大数的位数桐好改来算,我们需要8位的序列,那么我们就需要在1的前面补上7个零,只需要用下面的方法即可完成

select to_char(sysdate,'yyyyMMddHH24miss') || replace(lpad(common_sql.nextval,5,'0'),'','0') from dual;

黑体部分的函袜岩数lpad就是在左侧补零,rpad是右侧补零

整局判个sql还有其他部分,就是我们可以让序列以特定的开头展示,比如我们用年月日时分秒14位来作为我们序列的开头,就是上面完整的sql

oracle创建序列的语法

--创建序列的语法 --

CREATE SEQUENCE SEQ_POS_ORDER_ONLINE_ID

INCREMENT BY 1

START WITH 1000000000000042 -- 从1开始计数 或 MINVALUE 1 或 NOMINVALUE --的设置最小值 不设置最小值

NOMAXvalue -- 不设置最大值 或 MAXVALUE 10 --设置最大值 10

NOCYCLE -- 一直销卜累加,不循环 或

CACHE 10; --设置缓存cache个序列,亏茄穗如果系统down掉了或者其它情况将会导致序列不纳坦连续,也可以设置为---------NOCACHE

[img]

在oracle存储过程中建立序列

序列主要是用来生成固定的编号的,如:每次递增一即可。

create sequence SEQ_ID

minvalue 1

maxvalue 99999999

start with 1

increment by 1

cache 30

cycle;

之后执行:

insert into tab (auto_id) values (SEQ_ID.Nextval);

备注:sequence 是一个自山大增长的序列,每次调用nextval的时候会自动增加,可以定义起始值,最大值,增量,cycle是表慧唯拦前胡示循环,即到最大值后从起始值重新开始。 每次执行都是会自增的。

关于oracle创建序列和oracle创建序列号的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

标签列表