0
 
前言

用过 SQLserverMySQL 的自增列(auto_increment),然而 Oracle 在建表设置列时却没有自增列。

查阅资料后发现 Oracle 的自增列需要手动编写。

1
 
序列

 1.1、创建序列(sequence)

create sequence [sequence_name]  --创建序列
increment by 1 --递增步长为1
start with 1 --开始值为1
nomaxvalue --没有最大值 (设置最大值:maxvalue 1000)
minvalue 1 --最小值为1 (不设最小值:nominvalue)
nocycle --不循环 (设置循环:cycle)
cache 20; --缓存20 (不设缓存:nocache)

序列的所有属性都是选择设置(非必须设置),若全部属性使用默认值可直接使用 create sequence [sequence_name];

1.2、各属性默认值

  increment (步长): 1;

  start (开始值) : 1;

  maxvalue (最大值) : 10的28次方;

  minvalue (最小值) : 1 ;

  cycle (循环) : no ;

  cache (缓存) : 20 ;

  

1.3、序列使用

  1.3.1、当前序列值: [sequence_name].currval --当前序列值

     在dual表中查看当前序列值: select [sequence_name].currval from dual;

  1.3.2、下一个序列值(实现自增):  [sequence_name].nextval --下一个序列值

     初创建的序列必须先调用一次 nextval 才能使用 currval , 因为初次创建的序列没有当前值,所以必须产生一个值之后才有当前值。

1.4、序列中缓存的理解

  序列中的缓存是就是一次性储备一定数量的空间,类似数据库初创时设置的自增大小一样;当序列被使用至当前最大储备值时,系统将再次准备缓存数量的空间。用系统表  user_sequence  记录序列对象的变化来帮助理解缓存(重点看 last_number 的变化)。

  初创序列时的数据情况

  

  当调用一次 nextval 后

  

  当序列值使用到当前 laser_number 时, laser_number 值 = 当前last_number + cache_size

  

创建序列后就已经可以实现自增列的效果,例:

insert into ryxxb values (AUTOSEQ.nextval,'张三',AUTOSEQ.nextval + 100,'男')  --给人员信息表插入一条数据 id和编号 就使用序列

2
 
触发器

 2.1、创建触发器基本语法

CREATE OR REPLACE TRIGGER [trigger_name]
{[before] | [after] | [instead of]} --{[之前] | [之后 | [替换]} 触发时机
{[insert] | [delete] | [update[of column]]} --{[插入] | [删除] | [更新]{更新时可指定列名,仅在更新指定列时才会触发}} 触发操作
ON {[table_name] | [view_name]} --{[表明] | [视图名]} 触发器目标
[FOR EACH ROW] --可选 触发器类型 [FOR EACH ROW (行级触发器)] 或 语句触发器
[WHEN (condition)] --可选 触发条件 可选择加入触发条件
BEGIN
[pl\sql] --触发器执行内容
END

 2.2、为自动序列创建触发器

create trigger autotri  --创建触发器
before insert on ryxxb --[ryxxb]在执行[insert]操作之前触发
for each row --行级触发器
-- 触发器内容
begin
select autoseq.nextval into :new.ryid from dual; --取下一个序列值赋值给[ryid]字段
select (autoseq.currval + 100) into :new.rybh from dual; --取当前序列值赋值+100给[rybh]字段
end;

3
 
清空自动序列

3.1、手动清空序列

  1)查看当前序列的值: select seq_auto.currval from dual;

  

  2)根据当前序列值设置序列步长: alter sequence seq_auto increment by -120;

  3)获取next序列值: select seq_auto.nextval from dual;

  

  4)还原序列步长: alter sequence seq_auto increment by 1;

3.2、用储存过程实现自动清空序列

create or replace procedure pro_clear_seq(v_seqname varchar2)         -- 创建储存过程 par:要清空的序列名
as n number(10);
tsql varchar2(100);
begin
execute immediate 'select '||v_seqname||'.nextval from dual' into n; -- 获取序列当前值
n:=-(n-1);
tsql:='alter sequence '||v_seqname||' increment by '|| n; -- 更新步长为当前序列负值
execute immediate tsql;
execute immediate 'select '||v_seqname||'.nextval from dual' into n; -- 获取next序列值
tsql:='alter sequence '||v_seqname||' increment by 1'; -- 还原步长为1
execute immediate tsql;
end seq_reset;

执行储存过程:

begin
pro_clear_seq('seq_auto');
end;

<<============================================================================================================================================>>

此日记系列仅做普通开发使用Oracle,并非专业DBA

oracle入坑日记<六>自增列创建和清除(含序列和触发器的基础用法)的更多相关文章

  1. oracle入坑日记<四>表空间

    1   表空间是什么 1.1.数据表看做的货品,表空间就是存放货品的仓库.SQLserver 用户可以把表空间看做 SQLserver 中的数据库. 1.2.引用[日记二]的总结来解释表空间. 一个数 ...

  2. oracle入坑日记<三>用户详解(角色理解)

    1   用户是什么 1.1.权限管理是Oracle的精华,不同用户登录到同一数据库中,可能看到不同数量的表,拥有不同的权限.Oracle 的权限分为系统权限和数据对象权限,共一百多种.如果把Oracl ...

  3. oracle入坑日记<二>认识oracle(含sqlplus基础使用)

    1.SID(数据库实例) 1.1. oracle安装的时候有一项叫[全局数据库名]的填写项,这个就是oracle的SID也是数据库的唯一标识符: 1.2.一个oracle数据库有且只有一个SID(一般 ...

  4. oracle入坑日记<一> 安装

    学习日记系列(前辈/大神勿喷) 一.下载 下载地址:http://www.oracle.com/technetwork/cn/database/enterprise-edition/downloads ...

  5. oracle入坑日记<五>数据表

    1   数据表 1.1.数据表是存放数据字段信息的地方:在Oracle,数据表拥有者单位是用户,同时数据表属于表空间.如: 登录my_user用户在orcl表空间下创建的表就是 my_user用户在o ...

  6. Oracle自增列创建方法

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

  7. cozmo 入坑日记及开发环境搭建

    前几日,朋友在群里发了一个机器人的小视频,视频里机器人可以对话,可以推箱子,开心以后会哈哈大笑,非常有趣. 详细了解里一下,这是个叫 cozmo 的智能机器人,可以配合 SDK 用 python 编程 ...

  8. Vue入坑日记: day - 01

    前言 最近做了一些小项目,小组里写前端的确实有点拉胯,于是自己动手写前端,因为大一学过web前端基础,所以对HTML,CSS还有印象,就直接对JS下手了,学了两天把JS大致搞明白了,顺便对JQuery ...

  9. web前端入坑第五篇:秒懂Vuejs、Angular、React原理和前端发展历史

    秒懂Vuejs.Angular.React原理和前端发展历史 2017-04-07 小北哥哥 前端你别闹 今天来说说 "前端发展历史和框架" 「前端程序发展的历史」 「 不学自知, ...

随机推荐

  1. 20155219付颖卓 《网络对抗技术》 Exp9 Web安全基础

    实验后回答问题 1.SQL注入攻击原理,如何防御 ·SQL攻击的原理很简单,就是在用户名输入框里输入SQL语句,来欺骗数据库服务器进行恶意操作 ·防御可以从以下几个方面下手: (1)在web网页设计的 ...

  2. ORACLE数据库_迁移(新机器,新存储)

    迁移: (10g 64老机器,老存储) ------>(11g 64新机器,新存储)注意要点:新老服务的时间,字符集,sid升级顺序:10.2.0.1------>10.2.0.4或10. ...

  3. 一次奇妙的http请求之旅

    TCP/IP不是一个协议,而是一个协议族的统称.里面包括IP协议.IMCP协议.TCP协议. 这里有几个需要注意的知识点: 互联网地址:也就是IP地址,一般为网络号+子网号+主机号 域名系统:通俗的来 ...

  4. Redis管道功能

    Redis管道,Redis存储用户浏览数据 当频繁的存储获取Redis数据库中的数据时,可以使用Redis的pipeline(管道)功能,将多个相互没有依赖关系的读写操作,如:下一步执行的Redis操 ...

  5. sql注入-推断是否存在SQL注入-加法和减法

    这里我们需要区分一下数字型和字符串型: 数字型:不需要使用单引号来表示 其他类型:使用单引号来表示 综合上述,我们可以发现我们的例子是数字型的,这样我们就可以使用加法和减法来判断了. 加法,我们在参数 ...

  6. windows 端口转发

    1.添加端口转发 netsh interface portproxy add v4tov4 listenport=5000 listenaddress=10.30.3.148 connectport= ...

  7. H5外包 微信小程序外包 小程序外包 就找北京动点开发团队

    长年承接微信小程序.微信公众号开发 全职的H5开发团队,开发过几十款微信小程序公众号案例 欢迎来电咨询 QQ:372900288 微信:liuxiang0884 TEL:13911652504

  8. 数据分组分析—-groupby

    数据分组分析—-groupby 代码功能: 对于综合表格data,基于title进行分组处理,并统计每一组的size,得到的是一个series序列,此序列可以放入索引中使用,index() impor ...

  9. php7 使用simplexml扩展处理xml

    <?php $xmldoc = "<?xml version=\"1.0\" encoding=\"gb2312\"?> <s ...

  10. 借助微软提供的url重写类库URLRewriter.dll(1.0)实现程序自动二级域名,域名需要泛解析

    二级域名和系统中会员帐号自动关联,也就是系统中注册一个会员,会员自动就可以通过二级域名来访问,比如我的帐号是zhangsan,我在morecoder.com注册后,访问zhangsan.morecod ...