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

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

如今发现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. Eclipse项目包上出现红叉如何去除

    Eclipse项目包上出现红叉是因为jdk的版本不一致. 项目名--->Properties----->Java Compiler 图1:

  2. office 2010 破解

    使用Rearm命令激活延迟重置Office 20101.安装Offcie 2010 安装Offcie 2010,默认30天的试用期,这里要注意,上文提供的Office 2010是零售版,所以没有序列号 ...

  3. Laravel5.1 学习笔记2, 路由

    安装的说明请看文档, laravel 安装 #基本路由 你将在 app/Http/routes.php 文件定义大部分路由, 这些路由将被App\Providers\RouteServiceProvi ...

  4. HTTPS的中那些加密算法

    密码学在计算机科学中使用非常广泛,HTTPS就是建立在密码学基础之上的一种安全的通信协议.HTTPS早在1994年由网景公司首次提出,而如今在众多互联网厂商的推广之下HTTPS已经被广泛使用在各种大小 ...

  5. max-age 和 Expires

    网页的缓存是由HTTP消息头中的“Cache-control”来控制的,常见的取值有private.no-cache.max-age.must-revalidate等,默认为private.   Ex ...

  6. (2)dotnet开源电商系统-brnshop VS nopCommerce(dotnet两套电商来PK--第二篇:代码从哪开始-BrnMall3.0Beta)

    看大牛们的源码,对于水平一般的人,还是略微有点难度的.我从我自身读码的亲身体验,写下杂散片语,希望能和大家一同进步,也为了日后记忆上的备查. 先看的是brnMall的源码结构,从哪看起呢? 首先推荐看 ...

  7. 解决vcenter 6.0 vcsa安装插件时报错的问题

    在安装vCenter 6.0 vsca的时候,安装插件到第二个的时候,会报出一个windows installer的错误.需要联系软件管理员或者技术支持的一个error. 经过多次的测试,我终于找到了 ...

  8. Django--form组件cookie/session

    Field required=True, 是否允许为空 widget=None, HTML插件 label=None, 用于生成Label标签或显示内容 initial=None, 初始值 help_ ...

  9. PAT_A1132#Cut Integer

    Source: PAT A1132 Cut Integer (20 分) Description: Cutting an integer means to cut a K digits lone in ...

  10. eas之获得任何一个KDTable的选中行

    import com.kingdee.bos.ctrl.kdf.table.util.KDTableUtil; int[] selectRows =KDTableUtil.getSelectedRow ...