一个问题:

在某张表中,存在一个id列(整数),我们希望在添加记录的时候,该列从1开始,自动的增长,怎么处理?

解决方式:oracle是利用“序列”(sequence)来完成的。

序列(sequence)介绍

oracle中,是通过使用序列(sequence)来处理自动增长列。

(1)可以为表中的列自动产生值。

(2)由用户创建数据库对象,并可由多个用户共享。

(3)一般用于主键或唯一列。

创建序列基本语法:

create sequence 序列名称

start with 开始数字

increment by 增长数字

minvalue 最小值

maxvalue 最大值

cycle

nocache

详细说明:

start with 开始数字à从几开始

increment by 增长à步长,每次增长几个数

minvalue 最小值

maxvalue 最大值à可以不设置,不设置应写为nomaxvalue,也就是无穷大

cycle  循环,也就是说当长增长到最大值后,再从最小值开始重新增长

nocache 不设缓存

案例说明:

create sequence my_seq --创建序列名

start with 1            --从1开始

increment by 1          --每次增长1

maxvalue 999999999      --最大值 //nomaxvalue(不设置最大值)

minvalue 1              --最小值

cycle                   --循环 //nocycle(一直累加,不循环)

nocache                 --不使用缓存

解释:从1开始,每次增长1,最大值999999999,之后循环从1开始。

create sequence myseq

start with 0

increment by 1

minvalue 0

nomaxvalue

nocycle

nocache;

解释:从0开始,每次增长1,最小值0,无穷大,不循环一直累加。

sequence的使用:

create table test1(id number primary key,name varchar2(32));

insert into test1 values(myseq.nextval,'abc');

insert into test1 values(myseq.nextval,'ddd');

特别说明:

1、myseq:表示序列的名字,nextval:关键字,表示从序列中取下一个值。

2、sequence序列是需要配合number类型的列来使用;

3、sequence序列是要在主键或unique列上使用的。

问题:

如果system用户使用scott的sequence的序列时,sequence是从1增长还是从已使用到的数字开始?

答案:是从已使用到的数字接着增长。

细节说明:

看例子:

insert into emp values(my_seq.nextval,'tomcat','clerk',7566,sysdate,1200,null,20);

select my_seq.currval from dual;

注意:

第一次使用nextval返回的是初始值;

随后的nextval会自动增加你定义的increment by值,然后返回增加后的值;

currval总是返回当前sequence的值,但是在第一次nextval初始化之后才能使用currval,否则会出错。

使用一次nextval会增加一次sequence的值,所以如果你在同一个语句里面使用多个nextval,其值就是不一样的。

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

一旦定义了某个序列,你就可以用currval,nextval

currval:返回sequence的当前值

nextval:增加sequence的值,然后返回sequence值。

比如:

序列名.crrval

序列名.nextval

什么时候使用sequence?

不包含子查询、snapshot/view的select的语句

insert语句的子查询中

insert语句的values中

update的set中

如:update 表名 列值=序列名.nextval where 条件;

在sqlserver和mysql中都可以在定义表的时候,直接给指定自增长。

sqlserver中设置自增长

create table 表名(id int primary key identity(1,1),name varchar(32));

mysql中设置自增长

create table 表名(id int primary key auto_incrment,name varchar(32));

oracle数据库--序列(sequence)的更多相关文章

  1. EF中创建、使用Oracle数据库的Sequence(序列)功能

    ** 背景 ** 项目中订单号原来的生成规则由日期加随机数组成,后期需求决定将订单号生成规则更改为生成日期加当天当前订单数. 每天的订单数都是从0开始的,每生成一个订单,订单数就应该加1.订单数应该是 ...

  2. 【转】Oracle数据库中Sequence的用法

    在Oracle数据库中,sequence等同于序列号,每次取的时候sequence会自动增加,一般会作用于需要按序列号排序的地方. 1.Create Sequence (注释:你需要有CREATE S ...

  3. Oracle数据库---序列、索引、同义词

    --创建序列create sequence deptno_seqstart with 50increment by 10maxvalue 70cache 3; --为了方便演示,创建了一个和dept表 ...

  4. 序列sequence中的cache问题

    Oracle中序列Sequence的创建语法如下: CREATE SEQUENCE [ schema. ] sequence [ { INCREMENT BY | START WITH } integ ...

  5. ORACLE数据库入门再在屋里坐会

    一.数据库简介 数据库概述 数据库(database)是按照数据结构来组织,存储和管理数据的仓库,它产生与距今五十年前. 简单来说是本身可视为电子化的文件柜--存储电子文件的处所,用户可以对文件中的数 ...

  6. Oracle数据库中序列(SEQUENCE)的用法详解

    Oracle数据库中序列(SEQUENCE)的用法详解   在Oracle数据库中,序列的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值.本文我们主要介绍了 ...

  7. Oracle新表使用序列(sequence)作为插入值,初始值不是第一个,oraclesequence

    Oracle新表使用序列(sequence)作为插入值,初始值不是第一个,oraclesequence 使用oracle11g插入数据时遇到这样一个问题: 1 --创建测试表-- 2 CREATE T ...

  8. Oracle数据库学习 视图、序列及存储过程

    视图(View) 视图也被称作虚表,也就是虚拟的表,是一组数据的逻辑表示. 视图对应一个select语句,结果集被赋予一个名字,也就是视图的名字. 视图本身不包含任何数据,它只是包含映射到基表的一个查 ...

  9. Oracle数据库之序列

    Oracle数据库之序列(sequence) 序列是一个计数器,它并不会与特定的表关联.我们可以通过创建Oracle序列和触发器实现表的主键自增.序列的用途一般用来填充主键和计数. 一.创建序列 语法 ...

随机推荐

  1. linux2.6硬盘扇区直接读写程序

    下面的程序可以在linux2.6内核直接读写硬盘的指定扇区,也是根据网上一个朋友的做法做了修改的: 有两个不是很明白的地方就是:1.bd_claim函数的使用,这个是个递归函数,像是匹配内存指针和设备 ...

  2. freemarker写select组件(二)

    freemarker写select组件 1.宏定义 <#macro select id datas value=""> <select id="${id ...

  3. 翻译--Thinking in React

    无聊翻译篇react入门文章,去年学习react时看了一遍,很不错的一篇文章. https://reactjs.org/docs/thinking-in-react.html 部分为意译,旨在让new ...

  4. LeetCode 456. 132 Pattern

    问题描述 给一组数,判断这组数中是否含有132 pattern. 132 pattern: i < j < k, 且 ai < ak < aj 第一种解法 使用栈来保存候选的子 ...

  5. 【NOIP2013】华容道(最短路)

    题目戳我 懒得粘贴题目了..就这要凑合一下吧... 题解 反正棋盘的状态不会变的... 所以,预处理一下??? 恩,如果一个棋子要移动到某个目标位置的话, 可以看成只有空格和这个子要动呀(其他的有区别 ...

  6. POJ1743:Musical Theme

    题目 vjudge Sol 先差分 然后求不可重叠最长重复子串 bits/stdc++.h会CE # include <bits/stdc++.h> # define IL inline ...

  7. 自言自语WEB前端面试题(一)

    刚刚得到通知,明天可能要放半天假,开心的像个200斤的傻子 我怕真是个傻子,是后天 今天的我是依旧痛经的我 于是我又来写博客了 原来,博客竟是痛经良药 接下来请看题,此题,0难度,基本不需要动脑子 J ...

  8. tensorflow第一篇---numpy模块

    写在前面: 自学tensorflow半个月,博友们给了我很多帮助,这是我第一篇原创的博文,我想把之前的知识梳理一遍,我会分享我一些在学习过程中遇到的问题,我目前只有这些......... 在介绍ten ...

  9. error:org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.NullPointerException

    问题:调用的方法在一个接口类中,但我并没有注入那个被调用的类 解决:在UserEntity前加上@Autowired @Controller public class MainController { ...

  10. Unreachable statement

    public boolean onQueryTextSubmit(String s) { if (sv != null) { // 得到输入管理对象 InputMethodManager imm = ...