曾经最头疼的就是对表插入数据的时候,有主键问题。

由于主键不可以反复,所以得用函数自己定义一个规则生成不反复的值赋值给主键。

如今发现oracle有sequence就不用那么麻烦了。

转自:http://zhoufoxcn.blog.51cto.com/792419/166418/

先如果有这么一个表:


 
create table S_Depart    ( 

     DepartId                         INT                                                         not null, 

     DepartName                     NVARCHAR2(40)                                     not null, 

     DepartOrder                    INT                                                        default 0, 

     constraint PK_S_DEPART primary key (DepartId) 

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

1、Create Sequence 

你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限, 

CREATE SEQUENCE emp_sequence 

INCREMENT BY 1 -- 每次加几个 

START WITH 1 -- 从1開始计数 

NOMAXvalue -- 不设置最大值 

NOCYCLE -- 一直累加。不循环 

CACHE 10; --设置缓存cache个序列,假设系统down掉了或者其他情况将会导致序列不连续,也能够设置为---------NOCACHE

针对S_Depart创建的sequence例如以下:
 
create sequence S_S_DEPART 

minvalue 1 

maxvalue 999999999999999999999999999 

start with 1 

increment by 1 

nocache;
 
一旦定义了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 S_Depart(departId,Departname,Departorder)values(S_S_Depart.Nextval,'12345',1);
 
SELECT 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防止这样的情况。

2、Alter Sequence 

你或者是该sequence的owner,或者有ALTER ANY SEQUENCE 权限才干修改sequence. 能够alter除start至以外的全部sequence參数.假设想要改变start值。必须 drop sequence 再 re-create . 

Alter sequence 的样例 

ALTER SEQUENCE emp_sequence 

INCREMENT BY 10 

MAXvalue 10000 

CYCLE -- 到10000后从头開始 

NOCACHE ;


影响Sequence的初始化參数: 

SEQUENCE_CACHE_ENTRIES =设置能同一时候被cache的sequence数目。
能够非常easy的Drop Sequence 

DROP SEQUENCE order_seq;
一个简单的样例:

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,上面的代码就能够实现自己主动递增的功能了。

Oracle创建自增字段方法-ORACLE SEQUENCE的简介的更多相关文章

  1. Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍

    引用自 :http://www.2cto.com/database/201307/224836.html   Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...

  2. Oracle中创建自增字段方法

    oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现. 下面给大家讲个例子: 1.在Oracle中创建一个表: .创建一个表 ) prim ...

  3. Oracle创建自增字段和修改方法-ORACLE SEQUENCE的简单介绍

    http://blog.csdn.net/zhoufoxcn/article/details/1762351先假设有这么一个表: create table S_Depart  (    DepartI ...

  4. mongoose 创建自增字段方法

    first: create counter collection in mongodb:> db.counters.insert({_id:"entityId",seq:0} ...

  5. navicat for oracle 创建表ID字段的自动递增

    Oracle数据库创建表ID字段的自动递增   将表t_uaer的字段ID设置为自增:(用序列sequence的方法来实现) ----创建表 Create table t_user( Id numbe ...

  6. Oracle创建自增ID

    先创建序列sequence create sequence S_User minvalue 1 nomaxvalue  -- 或 maxvalue 999 start with 1 increment ...

  7. Oracle添加自增长字段方法步骤

    第一步:创建自增长序列 CREATE SEQUENCE ZH_ALARM_INFO_SEQ--自动增长列 INCREMENT BY 1 -- 每次加几个 START WITH 1 -- 从1开始计数 ...

  8. oracle触发器自增字段

    1.创建序列 代码 -- Create sequence create sequence seq_userinfo minvalue 1 start with 1 increment by 1; 2. ...

  9. oracle 创建自增主键

    1.创建表 create table Test_Increase( userid number(10) NOT NULL primary key, /*主键,自动增加*/ username varch ...

随机推荐

  1. ASP.NET Core 多环境

    ASP.NET Core 支持在多个环境中管理应用程序,如开发(Development),预演(Staging)和生产(Production).环境变量用来指示应用程序正在运行的环境,允许应用程序适当 ...

  2. A - Fox And Snake

    Problem description Fox Ciel starts to learn programming. The first task is drawing a fox! However, ...

  3. C - Lucky Numbers (easy)

    Problem description Petya loves lucky numbers. Everybody knows that positive integers are lucky if t ...

  4. 闲谈Spring-IOC容器

    闲聊 无论是做j2ee开发还是做j2se开发,spring都是一把大刀.当下流行的ssh三大框架中,spring是最不可替代的,如果不用hibernate和struts,我觉得都无关紧要,但是不能没有 ...

  5. NSLayoutConstraints加动画来改变约束

    // // ViewController.m // NSLayoutAnimationDemo // // Created by ebaotong on 15/7/22. // Copyright ( ...

  6. (转)vuex2.0 基本使用(3) --- getter

    有的组件中获取到 store 中的state,  需要对进行加工才能使用,computed 属性中就需要写操作函数,如果有多个组件中都需要进行这个操作,那么在各个组件中都写相同的函数,那就非常麻烦,这 ...

  7. JS的Key-Val(键值对)设置Key为动态的方法

    问题描述: 需要生成一个对象, 这个对象为 {key: value}, 现在要让key是动态的 解决方案: function(key, value){ let keyValue = {}; keyVa ...

  8. python 动态修改 类和实例 的方法

    相信很多朋友在编程的时候都会想修改一下已经写好的程序行为代码,而最常见的方式就是通过子类来重写父类的一些不满足需求的方法.比如说下面这个例子. class Dog: def bark(self): p ...

  9. 【第二课】kaggle案例分析二

    Evernote Export 推荐系统比赛(常见比赛) 推荐系统分类 最能变现的机器学习应用 基于应用领域分类:电子商务推荐,社交好友推荐,搜索引擎推荐,信息内容推荐等 **基于设计思想:**基于协 ...

  10. 504 Gateway Timeout 异常

    生产销售系统出现 504 Gateway Timeout 异常,其实就是服务器响应太慢导致nginx带来超时,先不说服务端慢的优化问题:只是单纯的解决504.到网上发现了一篇文章fix it Add ...