--------------------------------
在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方.
①.、Create
Sequence
你首先要有CREATE
SEQUENCE或者CREATE
ANY
SEQUENCE权限,
CREATE
SEQUENCE
emp_sequence
INCREMENT
BY
--
每次加几个
START
WITH
从1开始计数
NOMAXVALUE
不设置最大值
NOCYCLE
一直累加,不循环
CACHE
①.0;
一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL
CURRVAL=返回
sequence的当前值
NEXTVAL=增加sequence的值,然后返回
sequence
值
比如:
emp_sequence.CURRVAL
emp_sequence.NEXTVAL
可以使用sequence的地方:
-
不包含子查询、snapshot、VIEW的
SELECT
语句
INSERT语句的子查询中
NSERT语句的VALUES中
UPDATE
的
SET中
可以看如下例子:
INSERT
INTO
emp
VALUES
(empseq.nextval,
'LEWIS',
SYSDATE,
NULL,
empseq.currval
FROM
DUAL;
但是要注意的是:
第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT
BY值,然后返回增加后的值.CURRVAL
总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错.一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的.明白?
如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些.cache里面的取完后,oracle自动再取一组到cache.
使用cache或许会跳号,
比如数据库突然不正常down掉(shutdown
abort),cache中的sequence就会丢失.
所以可以在create
sequence的时候用nocache防止这种情况.
你或者是该sequence的owner,或者有ALTER
权限才能改动sequence.
可以alter除start至以外的所有sequence参数.如果想要改变start值,必须
drop
再
re-create
.
Alter
的例子
ALTER
MAXVALUE
①.0000
CYCLE
到10000后从头开始
NOCACHE
;
影响Sequence的初始化参数:
SEQUENCE_CACHE_ENTRIES
=设置能同时被cache的sequence数目.
可以很简单的Drop
DROP
order_seq;
如何使用Oracle序列:
Oracle序列(sequence)是一种数据库项,能够生成一个整数序列.通常用于填充数字类型的主键列.
①.、创建序列:
CREATE SEQUENCE sequence_name
[START WITH start_num]
[INCREMENT BY increment_num]
[{MAXVALUE maximum_num|NOMAXVALUE}]
[{MINVALUE minimum_num|NOMINVALUE}]
[{CYCLE|NOCYCLE}]
[{CACHE cache_num|NOCACHE}]
[{ORDER|NOORDER}]
其中:
start_num:序列开始整数
increment_num:每次增加的整数增量
maximum:序列最大整数
minimum:序列最小整数
CYCLE:循环生成
NOCYCLE:不循环生成,默认值
cache_num:保存在内存中的整数的个数
NOCACHE:不缓存任何整数
例如:
CREATE SEQUENCE seq_test;(默认值)
SELECT seq_test.nextval FROM dual;
ALTER SEQUENCE语句来修改序列.可以修改的内容:
不能修改序列的初值
序列的最小值不能大于当前值
序列的最大值不能小于当前值
DROP SEQUENCE seq_test;
①.、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
-不包含子查询、snapshot、view的select语句
-insert语句的子查询中
-nsert语句的values中
-update的set中
insertintoempvalues
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防止这种情况.
你或者是该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;
--创建序列的语法 --
CREATE SEQUENCE SEQ_POS_ORDER_ONLINE_ID
INCREMENT BY 1
NOMAXvalue -- 不设置最大值 或 MAXVALUE 10 --设置最大值 10
NOCYCLE -- 一直累加,不循环 或
CACHE 10; --设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为---------NOCACHE
以上就是土嘎嘎小编为大家整理的php备份数据库发邮件相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!