`

(转)oracle中的CURRVAL和NEXTVAL用法

    博客分类:
  • SQL
阅读更多

 转自:http://blog.csdn.net/qianyiyiding/article/details/51592689

 

1.什么是sequence?其作用是什么?

Oracle数据库中,什么是序列呢?其中的作用是什么呢?其实sequence是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。其主要的用途是生成表的主键值,可以在插入语句中引用,在插入之前,获取序列号nextval值,然后进行插入。也可以通过查询检查当前值,或使序列增至下一个值。

2.如何定义一个sequence?

  在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方或者在实际开发中,比如一个需求表格中的需求ID是唯一主键,都可以用sequence来获取。 
  首先在用Oracle序列号之前,我们首先得创建一个序列然后就可以通过CURRY、NEXTVAL,获取当前表中的返回sequence的当前值、下一个squence的值。可以通过下面的语句来创建Squence:

create sequence INR_REQUIRMENT_SQUENCE    
INCREMENT BY 1 -- 每次加几个  
START WITH 1 -- 从1开始计数  
NOMAXVALUE -- 不设置最大值  
NOCYCLE -- 一直累加,不循环  
CACHE 10;  

上面的语句则创建了一个INR_REQUIRMENT_SQUENCE序列

3.如何获取一个sequence的值?

  SELECT INR_REQUIRMENT_SQUENCE.CURRVAL FROM dual –获取当前的sequence的值, 
   第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值, 然后返回增加后的值。CURRVAL 总是返回当前sequence的值,但是在第一次NEXTVAL 初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次sequence的值, 所以如果你在同一个语句里面使用多个NEXTVAL。

4.可以在哪些地方使用Sequence?

  • 不包含子查询、snapshot、VIEW的 SELECT 语句
  • INSERT语句的子查询中
  • NSERT语句的VALUES中
  • UPDATE 的 SET中 
    在实际开发中,比如一个表中的主键需要先得到主键ID,可以用NEXTVAL来获下一个取序列值,然后再进行其他操作。

5.如何删除Sequence?

  DROP sequence policy_id_seq; –policy_id_seq为sequence的名字,如果要改变sequence中的初始值,必须先删除序列号然后再进行创建。你或者是该sequence的owner,或者有ALTER ANY sequence权限才能改动sequence,直接用Alter语句进行sequence的更新。

 

在oracle中sequence就是序号,每次取的时候它会自动增加。sequence与表没有关系。 

1、Create Sequence

    首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限。

    创建语句如下: 

 

 
CREATE SEQUENCE seqTest
INCREMENT 
BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXvalue -- 不设置最大值
NOCYCLE -- 一直累加,不循环
CACHE 10--设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为---------NOCACHE
 

 

 

2、得到Sequence值 

定义好sequence后,你就可以用currVal,nextVal取得值。
    CurrVal:返回 sequence的当前值 
    NextVal:增加sequence的值,然后返回 增加后sequence值 

  得到值语句如下:
SELECT Sequence名称.CurrVal FROM DUAL; 

  如得到上边创建Sequence值的语句为:

select seqtest.currval from dual

 

 

在Sql语句中可以使用sequence的地方: 
    - 不包含子查询、snapshot、VIEW的 SELECT 语句 
    - INSERT语句的子查询中 
    - INSERT语句的values中 
    - UPDATE 的 SET中

如在插入语句中

 

insert into 表名(id,name)values(seqtest.Nextval,'sequence 插入测试');

 

 

 注:

    - 第一次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防止这种情况。

 

 

 

 

3、Alter Sequence 
    拥有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create。

 

例:

alter sequence SEQTEST maxvalue 9999999;
    另: SEQUENCE_CACHE_ENTRIES参数,设置能同时被cache的sequence数目。

 

4、Drop Sequence
DROP SEQUENCE seqTest; 

 

 

5、一个例子

 

 
create sequence SEQ_ID
minvalue 
1
maxvalue 
99999999
start 
with 1
increment 
by 1
nocache
order;

建解发器代码为:

create or replace trigger tri_test_id
  before 
insert on S_Depart   --S_Depart 是表名
  for each row
declare
  nextid 
number;
begin
  
IF :new.DepartId IS NULLor :new.DepartId=0 THEN --DepartId是列名
    select SEQ_ID.nextval --SEQ_ID正是刚才创建的
    into nextid
    
from sys.dual;
    :new.DepartId:
=nextid;
  
end if;
end tri_test_id;
 

 

     OK,上面的代码就可以实现自动递增的功能了。

 

 

 

    注::new 代表 数据改变后的新值,相对应的有 :old 原值

          := 代表 赋值

          :nextid表示引用sqlplus中定义的变量 

                      

分享到:
评论

相关推荐

    mysql currval 和 nextval 函数的实现.txt

    mysql currval 和 nextval 函数的实现

    sequence等同于序列号

    在Oracle数据库中,sequence等同于序列号,每次取的时候sequence会自动增加,一般会作用于需要按序列号排序的地方。 1、Create Sequence (注释:你需要有CREATE SEQUENCE或CREATE ANY SEQUENCE权限) CREATE ...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    Oracle中权限主要分为两种,系统权限和实体权限。  系统权限:系统规定用户使用数据库的权限。(系统权限是对用户而言)。  DBA: 拥有全部特权,是系统最高权限,只有DBA才可以创建数据库结构。  RESOURCE:...

    oracle数据库经典题目

    C.Oracle中的同义词分为公有同义词和私有同义词 D.公有同义词在数据库中所有的用户都可以使用;私有同义词由创建它的用户所拥有 25. 下列哪个锁模式不属于Oracle?( D ) A. 共享锁 B.排他锁 C. 行级共享锁 D. ...

    MySQL实现类似Oracle序列的方案

    MySQL实现类似Oracle的序列...Oracle序列的使用,无非是使用.nextval和.currval伪列,基本想法是: 1、MySQL中新建表,用于存储序列名称和值; 2、创建函数,用于获取序列表中的值; 具体如下: 表结构为:  drop tabl

    Oracle8i_9i数据库基础

    §3.3.8 标记不使用的列和删除不使用的列 104 §3.3 主键 106 §3.3.1 创建主键 106 §3.3.2 改变主键 109 §3.3.3 删除主键 109 §3.4 外部键 110 §3.4.1 建立外部键 110 §3.4.2 修改外部键 112 §3.4.3 删除外部...

    Oracle事例

    20.oracle8中扩充了group by rollup和cube的操作。有时候省了你好多功夫的。 下面的语句可以进行总计 select region_code,count(*) from aicbs.acc_woff_notify group by rollup(region_code); <2> 对第1个字段...

    11.Oracle序列生成器1

    2、在dual虚表使用序列序列创建后,用序列名.nextval获取序列的下一个值,用序列名.currval来查看当前值 3、在SQL语句中使用序列我们先创建一个

    PostgreSQL教程(七):函数和操作符详解(3)

    下面序列函数,为我们从序列对象中获取最新的序列值提供了简单和并发读取安全的方法。   函数 返回类型 描述 nextval(regclass) bigint 递增序列对象到它的下一个数值并且返回该值。这个动作是自动完成的。...

    SQL培训第一期

    属性不依赖于其它非主属性,确保数据表中的每一列数据都和主键直接相关,而不能间接相关,即要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。 1.5.3.2 举例 党员表 党员Id 党员姓名 组织Code 符合3NF ...

    刚做的一个投票系统

    功能齐全,有后台管理添加投票,删除,修改等,用到一些基本的session,(可以方便的进行一次性添加,删除再来更新)和javascrpit代码。前台可根据后台所选择的主题来显示,以及进行投票,欢迎初学者学习。 详细说明...

    总结了java容易出错的信息 以及错误信息类型

    总结了java容易出错的信息 以及错误信息类型

Global site tag (gtag.js) - Google Analytics