首先咱先建一张表:

  

CREATE TABLE example(

  ID Number(4) NOT NULL PRIMARY KEY,

  NAME VARCHAR(25),

  PHONE VARCHAR(10),

  ADDRESS VARCHAR(50) );

然后咱再建一个自定义的序列:

  

CREATE SEQUENCE emp_sequence

  INCREMENT BY 1 -- 每次加几个

  START WITH 1 -- 从1开始计数

  NOMAXVALUE -- 不设置最大值

  NOCYCLE -- 一直累加,不循环

  NOCACHE -- 不建缓冲区

还需要一个触发器

 CREATE TRIGGER "触发器名称" BEFORE

  INSERT ON example FOR EACH ROW WHEN (new.id is null)

  begin

  select emp_sequence.nextval into: new.id from dual;

  end;

 打完收工!下面你就试试插入数据吧!

  INSERT INTO example(Name,phone,address) Values('Cao','56498543','Heibei');

  ==================================================================================

  ORACLE SEQUENCE的简单介绍(自增长字段)- -

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

  1、Create Sequence

  你首先要有Create Sequence或者Create AnySequence权限,

  Create Sequence emp_sequence

  INCREMENT BY 1    --每次加几个

  STARTWITH 1    --从1开始计数

  NOMAXVALUE    --不设置最大值

  NOCYCLE    --一直累加,不循环

  CACHE10 ;

  一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL

  CURRVAL=返回sequence的当前值

  NEXTVAL=增加sequence的值,然后返回sequence值

  比如:

  emp_sequence.CURRVAL

  emp_sequence.NEXTVAL

  可以使用sequence的地方:

  -不包含子查询、snapshot、VIEW的SELECT语句

  -INSERT语句的子查询中

  -INSERT语句的VALUES中

  -UPDATE的SET中

  可以看如下例子:

  INSERT INTO emp VALUES

  (empseq.nextval,'LEWIS','CLERK',7902,SYSDATE,1200,NULL,20);

  SELECT empseq.currval FROM DUAL;

  但是要注意的是:

  第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENTBY值,然后返回增加后的值。CURRVAL总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?

  如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。使用cache或许会跳号,比如数据库突然不正常down掉(shutdownabort),cache中的sequence就会丢失.所以可以在createsequence的时候用nocache防止这种情况。

  2、Alter Sequence

  你或者是该sequence的owner,或者有ALTER ANYSEQUENCE权限才能改动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数目。

  可以很简单的Drop Sequence

  DRO SEQUENCE order_seq;

  -------------------------------------------------------------

  自增长及触发器:

  如何在Oracle中实现类似自动增加ID的功能?

  我们经常在设计数据库的时候用一个系统自动分配的ID来作为我们的主键,但是在ORACLE中没有这样的功能,我们可以通过采取以下的功能实现自动增加ID的功能

  1.首先创建sequence

  create sequence seq maxincrement by 1

  2.使用方法

  select seqmax.nextval ID from dual

  就得到了一个ID

  如果把这个语句放在触发器中,就可以实现和mssql的自动增加ID相同的功能!

  -------------------------------------------------------------------------

  ###建表###

  CREATE TABLE "SPORTS"."LINEUP"("ID" NUMBER NOT NULL,

  "TYPE" NUMBER(3) NOT NULL,

  "BODY" VARCHAR2(100) NOT NULL,

  "HITS" NUMBER(10) DEFAULT 0 NOT NULL,

  PRIMARYKEY("ID"))

  TABLESPACE "TS_SPORTS"

  ###建序列###

  CREATE SEQUENCE "SPORTS"."SPORTS_LINEUP_ID_SEQ" INCREMENT BY 1

  START WITH 1 MAXVALUE 1.0E28 MINVALUE 1 NOCYCLE

  CACHE 50 NOORDER

  ###建自动更新的触发器###

  CREATE OR REPLACE TRIGGER "SPORTS"."SPORTS_LINEUP_ID_TRIGGER"

  BEFORE INSERT ON "SPORTS"."LINEUP" FOR EACH ROW

  DECLARE

  next_id NUMBER;

  BEGIN

  --Get the next id number from the sequence

  SELECT sports_lineup_id_seq.NEXTVAL INTO next_id FROM dual;

  --Use the sequence number as the primarykey

  --for there cord being inserted.

  :new.id:=next_id;

  END;

  ###建保护PRIMARYKEY的触发器###

  CREATE OR REPLACE TRIGGER "SPORTS"."LINEUP_ID_UPDATE_TRIGGER"

  BEFORE UPDATE OF "ID" ON "SPORTS"."LINEUP" FOR EACHROW

  BEGIN

  RAISE_APPLICATION_ERROR(-20000,

  'sports_lineup_id_update_trigger:Update sof the ID field'

  ||'arenotallowed.');

  END;

  ###建删除的触发器###

  create   or replace trigger tr_bis_exc_req_del

  before delete

  on bis_exc_req

  referencing old as old new as new

  for each row

  begin

  if :old.check_status = '3' then

  raise_application_error (-20001,'*****!');

  return;

  end if;

  end;

  /

  ###建更新的触发器###

  create   or replace trigger tr_bis_exc_req_upd

  before update

  on bis_exc_req

  referencing old as old new as new

  for each row

  begin

  if :old.check_status = '3' then

  raise_application_error (-20001,'*******!');

  return;

  end if;

  end;

Oracle 自增写给自己的的更多相关文章

  1. mvc模式jsp+servel+dbutils oracle基本增删改查demo

    mvc模式jsp+servel+dbutils oracle基本增删改查demo 下载地址

  2. mvc模式jsp+servel+jdbc oracle基本增删改查demo

    mvc模式jsp+servel+jdbc oracle基本增删改查demo 下载地址

  3. web项目总结——通过jsp+servlet实现对oracle的增删改查功能

    1.DAO模式 分包:依次建立 entity:实体包,放的是跟oracle数据库中表结构相对应的对象的属性,也就是这个对象有什么 dao:增删改查接口,实现增删改查的具体方法 service:同dao ...

  4. Oracle自增列创建方法

    最近在做Oracle的项目,由于以前没有接触过Oracle的开发,遇到了不少的问题,比如给Oracle表添加自增列,与SQL Server就不同. Oracle没有自增字段这样的功能,但是通过触发器( ...

  5. JDBC概述及JDBC完成对Oracle的增删改查

    什么是JDBC JDBC(Java Data Base Connectivity,Java数据库连接),是一种用于执行SQL语句的Java API,为多种关系数据库提供统一访问.它由一组用Java语言 ...

  6. C# 连接 Oracle数据库增删改查,事务

    一. 前情提要 一般.NET环境连接Oracle数据库,是通过 TNS/SQL.NET 配置文件,而 TNS 必须要 Oracle 客户端(如果连接的是服务器的数据库,本地还要装一个 client , ...

  7. oracle 定时任务增、删、改、查

    增: 创建一个计划任务 begin sys.dbms_job.submit(job=>:job, what=>'要定时执行的存储过程名:',--例如:包名.存储过程名;  记得写分号 ne ...

  8. oracle归档日志写满错误解决方法

    最近一年,手头上负责的项目要部署到很多个地方,由于项目组里没有人对oracle比较熟悉,只能给自己增加一个DBA的角色了.由于短时间内要部署很多单位,备份策略没有设置好,结果过了一个月,用户报告程序开 ...

  9. oracle DBA坚持写博客的7大理由

    对于Oracle DBA来说,甚至IT技术人员来说.坚持写博客是个好习惯.以下是我建议大家写博客的七个理由. 帮助整理思路 最近我做出了一个决定,那就是: 我要坚持天天写博客,记录每天所学的重要东西. ...

随机推荐

  1. FYI-django数据库操作-外键

    我先定义两个模型,一个是作者,一个是作者出版的书籍,算是一对多的类型.   class Person(models.Model); name = models.CharField('作者姓名', ma ...

  2. selenium项目--读取测试用例

    读取测试用例 一直我们都没有考虑过读取测试用例的事,我们现在这样设计测试用例有两个好的点,在执行方法时,打印测试用例,方便知道执行的内容是什么,在报告展示时,把测试用例的结果展示出来 实现方案:目前我 ...

  3. Gym 100169A 最短路

    题意:不久后滑铁卢将会变得非常冷,但是幸运的是,很多建筑都被桥梁和隧道连接着,所以你不需要总是走在外面.但是现在建筑 物之间的连接是错综复杂的,很难知道某两个建筑物之间的最优路线,所以需要你写程序判断 ...

  4. pooling

    转自:http://www.gageet.com/2014/09182.php 本文部分参考了:http://www.zhihu.com/question/23437871 卷积层是对图像的一个邻域进 ...

  5. C-net总结

    SMB服务器信息块   DHCP动态主机配置协议 STMP简单邮件传输协议 POP(邮件协议) Gnutella   网络分析数据   nslookup DNS(域名系统)  请求注释(RFC)文件 ...

  6. BootStrap中常用样式类

    网格选项 row:行 col--:列(第一个可以为xs[超小]/sm[小型]/md[中型]/lg[大型]:第二个必须为12以内的[列数]) col--offset-:列偏移(第一个同上,第二个范围为1 ...

  7. scrapy--BeautifulSoup

    BeautifulSoup官方文档:https://beautifulsoup.readthedocs.io/zh_CN/latest/#id8 太繁琐的,精简了一些自己用的到的. 1.index.h ...

  8. 用PHP关于Jquery表单插件ajaxForm里success不返回问题

    简单说一下吧,在用ajaxForm的时候,sucess突然之间不返回了,直接转到error里面去, 网页代码 ................. $('#add-type').ajaxForm({ d ...

  9. 环形缓冲区实现类(Delphi)

    环形缓冲区的用途及原理可以去百度资料狠多的,这里就不介绍了.直接贴代码.代码分别用D7,XE2编译测试 源码下载 http://files.cnblogs.com/lwm8246/uCircleBuf ...

  10. Linux系统Mini版配置相关

    一:修改ip 编辑:vi /etc/sysconfig/network-sc/ifcfg-eth0 配置如下图: