首先咱先建一张表:

  

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. C# 驱动的mongodb的分页查询简单示例

    /// <summary> /// mongodb分页查询 /// </summary> /// <typeparam name="T">< ...

  2. swift 注解 (和java比照)@attribute name

    Attributes provide more information about a declaration or type. There are two kinds of attributes i ...

  3. mayan 游戏真是毒瘤

    如题 真坑呀!!! 可算过了 我率先达到了氧气富有化 先是改变时没有fall.40分 然后是fall函数写慢了 tle 50分 . 上代码 #include<cstdio> #includ ...

  4. 重定向跳出父Frame

    当session过期后可以用过滤器来设置重定向页面 代码如下: public class ActionFilter extends HttpServlet implements Filter {pri ...

  5. 【Java】对象、类(抽象类与内部类)、接口

    博文内容概况 对象和类 抽象类 接口 内部类 对象和类 对象是对客观事物的抽象,类是对对象的抽象.类是一种数据类型,其外观和行为由用户定义.类中可以设置两种类型的元素:字段(有时被称为数据成员)和方法 ...

  6. Map the Debris -freecodecamp算法题目

    Map the Debris 1.要求 返回一个数组,其内容是把原数组中对应元素的平均海拔转换成其对应的轨道周期. 原数组中会包含格式化的对象内容,像这样 {name: 'name', avgAlt: ...

  7. Linux关闭开启防火墙命令

    在外部访问CentOS中部署应用时,需要关闭防火墙. 关闭防火墙命令:systemctl stop firewalld.service 开启防火墙:systemctl start firewalld. ...

  8. 侯捷《C++面向对象开发》——动手实现自己的复数类

    前言 最近在看侯捷的一套课程<C++面向对象开发>,刚看完第一节introduction之后就被疯狂圈粉.感觉侯捷所提及所重视的部分也正是我一知半解的知识盲区,我之前也写过一些C++面向对 ...

  9. tcl之文件操作

  10. 关于TP3.2框架读取Sql server中文字段数据以及处理乱码的一些小心得

    最近要做一个项目,需要使用TP3.2框架,之前什么也不会,就硬着头皮上了,结果真的闹了挺多emmmmmm挺低级的错误,就像SQL Server中文字段的读取,一开始我是照着读取英文字段的格式来写的,在 ...