首先咱先建一张表:

  

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. 委托代码func和Action的基本用法

    这是微软简化后的委托写法,其中,func适合带返回参数的方法调用,action适合没有返回参数的方法调用 FUNC方法代码: public string GetPeopleInfo(string na ...

  2. C++11 新特性之 序列for循环

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/lr982330245/article/details/30971195 在C++中在C++中for循 ...

  3. 简单的Nodejs模块

    说千遍,道万遍,不如动手做一遍,我们实现一个node所谓的模块 看下上面的图,了解一下模块自始至终的一个流程,首先是创建模块,也就是一个入口的js文件,里面加了一些特定的功能,然后导出这个模块, ex ...

  4. 2017.10.27 C语言精品集

    第一章 程序设计和C语言 1.1 什么是计算机程序? @ ······ 所谓程序,就是一组计算机能识别和执行的指令.每一条指令使计算机执行特定的操作. 计算机的一切操作都是由程序控制的.所以计算机的本 ...

  5. 20145238-荆玉茗 《Java程序设计》第9周学习总结

    20145238第九周<Java学习笔记> 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 ...

  6. Spring任务执行器(TaskExecutor)

    Spring任务执行器(TaskExecutor)    Spring通州任务执行器(TaskExecutor)来实现多线程和并发编程,使用ThreadPoolTaskExecutor可实现一个基于线 ...

  7. centos开启rewrite功能

    首先找到 /etc/httpd/conf/httpd.conf 文件,然后修改以下两个地方: 1.取消下面一句的注释 LoadModule rewrite_module modules/mod_rew ...

  8. JavaEE权限管理系统的搭建(三)--------springmvc和mabatis整合环境搭建

    本节介绍如何环境的搭建和配置: 首先要在父工程引入jar包依赖: <!-- 通过属性定义指定jar的版本 --> <properties> <spring.version ...

  9. mybatis-generator的maven插件使用异常(mybatis-generator-maven-plugin):generate failed: Exception getting JDBC Driver

    使用mybatis的代码生成工具:mybatis-generator,在父model中引入了maven插件的依赖,如下: <!-- Mybatis.generator插件 --> < ...

  10. Login用户登录(Python实现)

    username_fault = "isuperSun" #程序存储用户名和密码 password_fault = " counts = 0 while counts&l ...