首先咱先建一张表:

  

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. 分享个谷歌浏览器下的一款插件PostMan

    用作POST GET调试非常好用 先下载谷歌浏览器 然后在应用里搜索安装即可

  2. python web应用--WSGI接口(二)

    WSGI接口定义非常简单,它只要求Web开发者实现一个函数,就可以响应HTTP请求.我们来看一个最简单的Web版本的“Hello, web!”: 1 # server.py 2 # 从wsgiref模 ...

  3. P1567 统计天数

    题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...

  4. 2017.9.18 include指令和include动作有什么区别?

    问题:include指令和include动作有什么区别? 答:include指令合并静态文档或Jsp页面中的内容,可以用于包括动态生成的输出结果,因此可以包含一个Servlet include指令在编 ...

  5. Spring Quartz *.QRTZ_LOCKS' doesn't exist

    ERROR [org.springframework.web.context.ContextLoader] - Context initialization failedorg.springframe ...

  6. redux详解

    redux介绍 学习文档:英文文档,中文文档,Github redux是什么 redux是一个独立专门用于做状态管理的JS库(不是react插件库),它可以用在react, angular, vue等 ...

  7. 漂亮提醒框js

    <script type="text/javascript"> var filename = "PICC_V2.1.3.0_新增功能操作手册.doc" ...

  8. Spring Cloud 升级最新 Finchley 版本,踩坑指南!

    https://blog.csdn.net/youanyyou/article/details/81530240 Spring Cloud 升级最新 Finchley 版本,踩了所有的坑! 2018年 ...

  9. IntelliJ IDEA 方法注释教程

    首先Ctrl +Alt +S ,打开Settings ,找到Live Template,然后点击右侧的绿色的“+”,选择Template Group 然后给新建的Group随便命个名 选中自己刚才创建 ...

  10. spring框架中@PostConstruct的实现原理

    在spring项目经常遇到@PostConstruct注解,首先介绍一下它的用途: 被注解的方法,在对象加载完依赖注入后执行. 此注解是在Java EE5规范中加入的,在Servlet生命周期中有一定 ...