序列的作用

  • 许多的数据库之中都会为用户提供一种自动增长列的操作,例如:在微软的Access数据库之中就提供了一种自动编号的增长列(ID列)。在oracle数据库中没有自动增长列.
  • 序列(Sequence)可以自动的按照即定的规则实现数据的编号操作。

序列的创建语法

CREATE SEQUENCE 序列名称

[ INCREMENT BY 步长 ]

[ START WITH 开始值 ]

[ MAXVALUE 最大值 | NOMAXVALUE ]

[ MINVALUE 最小值 | NOMINVALUE ]

[ CYCLE | NOCYCLE ]

[ CACHE 缓存大小 | NOCACHE ] ;

创建默认序列:最小值为0,最大值为无限大

创建默认序列的语法

CREATE SEQUENCE 序列名称 ;

创建一个myseq的默认序列

CREATE SEQUENCE myseq;

利用数据字典查询序列—— user_sequences

  • SELECT * FROM user_sequences;

各个主要属性内容:

SEQUENCE_NAME

表示序列的名称,此处的名称为之前创建的“MYSEQ”;

MIN_VALUE

此序列开始的默认最小值(默认是0);

MAX_VALUE

此序列增长的默认最大值(默认是999999999999999999999999999);

INCREMENT_BY

序列每次增长的步长(默认是1);

CYCLE_FLAG

循环标记,如果是循环序列则显示“Y”,非循环序列则显示为“N”(默认是“N”);

CACHE_SIZE

序列操作的缓存量(默认是20);

LAST_NUMBER

最后一次操作的数值;

使用序列

  • 要使用一个已经创建完成的序列,则可以使用序列中提供的两个伪列进行操作:
  • 对于给出的伪列,一定是先使用nextval,再使用currval
  • 每次执行nextval发现序列的内容会增加,而调用currval时序列不会有变化
  • 对于序列中缓存是一个非常重要的概念,在序列使用前,已经在内存里面为用户提供好了一系列的生成的序列号.用的时候不是随用随取,而是已经准备好了.
  • 缓存能让我们的序列操作更快,如果设置了缓存,数据库出现系统关闭时,可能缓存的数据会消失,它知会记住左后一个值LAST_NUMBER。如果再次使用,可能出现跳号问题。

序列名称.currval

表示取得当前序列已经增长的结果,重复调用多次后序列内容不会有任何变化,同时当前序列的大小(LAST_NUMBER)不会改变;

SQL> SELECT myseq.nextval FROM dual;

序列名称.nextval

表示取得一个序列的下一次增长值,每调用一次,序列都会自动增长;

SQL> SELECT myseq.currval FROM dual;

  • 序列最终的目的是生成自动增长列,必须结合表来使用.

member表的数据库创建脚本

DROP TABLE member PURGE ;

CREATE TABLE member (

mid   NUMBER        PRIMARY KEY ,

name VARCHAR2(50) NOT NULL

) ;

编写数据插入语句,向member表中增加记录

INSERT INTO member(mid,name) VALUES(myseq.nextval,'WENDY');

SELECT * FROM member;

序列的删除

  • 在Oracle之中,序列也是作为Oracle数据库的一个对象存在的,所以如果现在要删除一个不再使用的序列,则可以继续利用DROP语句完成。

删除序列的语法

DROP SEQUENCE 序列名称 ;

删除myseq序列

DROP SEQUENCE myseq ;

创建特殊功能的序列

默认情况下序列的步长为1,就是每次增加的内容为1.

创建序列并由用户设置序列的增长步长

CREATE SEQUENCE 序列名称 INCREMENT BY 步长 ;

创建一个新的序列,让其每次的增长步长3

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq INCREMENT BY 3 ;

默认的初始值为1开始的.

创建序列并由用户设置序列的初始值

CREATE SEQUENCE 序列名称 START WITH 初始值 ;

创建序列,让其初始值设置为30,每次增长步长为2

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq

INCREMENT BY 3

START WITH 30 ;

序列缓存

CACHE保存的是缓存的个数,而不是数值.

  

设置缓存

创建序列并由用户设置缓存操作

CREATE SEQUENCE 序列名称 CACHE 缓存大小 | NOCACHE ;

创建序列,缓存设置为100

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq CACHE 100 ;

不设置缓存

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq NOCACHE ;

循环序列

希望序列在一个数值范围内

创建循环序列

CREATE SEQUENCE 序列名称

[ MAXVALUE 序列最大值 | NOMAXVALUE ]

[ MINVALUE 序列最小值 | NOMINVALUE ]

[ CYCLE | NOCYCLE ] ;

创建循环序列,让序列的内容在1、3、5、7、9之间循环

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq

START WITH 1

INCREMENT BY 2

MAXVALUE 10

MINVALUE 1

CYCLE

CACHE 3 ;

修改序列

序列本身也属于一个数据库的对象,而只要是数据库的对象,那么在创建之后都可以对其进行修改.

序列的修改语法

ALTER SEQUENCE 序列名称

[ INCREMENT BY 步长]

[ MAXVALUE 最大值 | NOMAXVALUE ]

[ MINVALUE 最小值 | NOMINVALUE ]

[ CYCLE | NOCYCLE ]

[ CACHE 缓存大小 | NOCACHE ] ;

范例:创建一个基本序列

DROP SEQUENCE myseq ;

CREATE SEQUENCE myseq ;

范例:修改myseq序列

ALTER SEQUENCE myseq

INCREMENT BY 10

MAXVALUE 98765

CACHE 100 ;

自动序列

从Oracle 12C起,为了方便用户生成数据表的流水编号,所以提供了类似于DB2或MySQL那样的自动增长列,而这种自动增长列实际上也是一个序列,只是这个序列对象的定义是由Oracle数据库自己控制的。

Generated by default as identity

Oracle的自动增长序列,需要在定义列的时候进行设置,而设置的语法:

CREATE TABLE 表名称 (

列名称    类型    GENERATED BY DEFAULT AS IDENTITY ([ INCREMENT BY 步长 ]

[ START WITH 开始值 ]

[ MAXVALUE 最大值 | NOMAXVALUE ]

[ MINVALUE 最小值 | NOMINVALUE ]

[ CYCLE | NOCYCLE ]

[ CACHE 缓存大小 | NOCACHE ]) ,

列名称    类型 ,…

) ;

创建带有自动增长列的数据表

DROP TABLE mytab PURGE ;

CREATE TABLE mytab (

mid    NUMBER   GENERATED BY DEFAULT AS IDENTITY (START WITH 1 INCREMENT BY 1) ,

name    VARCHAR2(20)    NOT NULL ,

CONSTRAINT pk_mid PRIMARY KEY(mid)

) ;

Oracle Schema Objects——Sequences(伪列:nextval,currval)的更多相关文章

  1. Oracle Schema Objects——伪列ROWID Pseudocolumn(ROWNUM、ROWID)

    Oracle Schema Objects Oracle Schema Objects——Tables——Oracle Data Types Oracle伪列 在Oracle数据库之中为了实现完整的关 ...

  2. Oracle Schema Objects——Tables——Oracle Data Types

    Oracle Schema Objects Oracle Data Types 数据类型 Data Type Description NUMBER(P,S) Number value having a ...

  3. Oracle Schema Objects(Schema Object Storage And Type)

    One characteristic of an RDBMS is the independence of physical data storage from logical data struct ...

  4. Oracle Schema Objects——Index

    索引主要的作用是查询优化. Oracle Schema Objects 查看执行计划的权限:查看执行计划plustrace:set autotrace trace exp stat(SP2-0618. ...

  5. Oracle Schema Objects——View

    Oracle Schema Objects Oracle视图View 普通视图.物化视图 视图(视图不包含数据,不是段对象,不占用空间,只是一个代码.) 作用: 简化SQL 为安全,不暴露表的名称 视 ...

  6. Oracle Schema Objects——Tables——TableStorage

    Oracle Schema Objects Table Storage Oracle数据库如何保存表数据? Oracle Database uses a data segment in a table ...

  7. Oracle Schema Objects——Tables——TableType

    Oracle Schema Objects Object Tables object type An Oracle object type is a user-defined type with a ...

  8. Oracle Schema Objects——Tables——Overview of Tables

    Oracle Schema Objects Overview of Tables A table is the basic unit of data organization in an Oracle ...

  9. Oracle Schema Objects——Tables——Table Compression

    Oracle Schema Objects Table Compression 表压缩 The database can use table compression to reduce the amo ...

随机推荐

  1. static、extern分析

    1.extern extern在变量声明中有这样一个作用:你要在demo2.cpp中引用demo1.cpp中的一个全局变量,就要在demo2.h中用extern来声明这个全局变量(或者在demo1.h ...

  2. R语言低级绘图函数-abline

    abline 函数的作用是在一张图表上添加直线, 可以是一条斜线,通过x或y轴的交点和斜率来确定位置:也可以是一条水平或者垂直的线,只需要指定与x轴或y轴交点的位置就可以了 常见用法: 1)添加直线 ...

  3. 支付宝(移动支付)服务端java版

    所需支付宝jar包: sdk2-2.0.jar(点击下载) 工具类目录结构:   点击下载 商户信息已经公钥私钥的配置(公钥私钥的生成与支付宝商户平台配置请看官方文档:https://doc.open ...

  4. R基本介绍

    一.基本介绍:1. 警告:在输入命令前请切换到英文模式.否则你的一大段代码可能因为一个中文状态的括号而报错,R语言的报错并不智能无法指出错误的具体位置.最可怕的是不报错但就是无法输出正确结果.2. 警 ...

  5. 动态提交使用jQuery 完成ajax 文件下载----后端php

    1.js代码 // Ajax 文件下载 //当不用传参时,可以将data去掉 jQuery.download = function(url, data, method){ // 获得url和data ...

  6. Xshell通过ssh方式连接Linux服务器,通过Xftp进行文件传输

    准备工作: 一.Linux服务器一台,并配置ssh(本文以腾讯云服务器为例). 1.生成秘钥 打开腾讯云控制台,依次选择:总览->云服务器->SSH秘钥 点击创建秘钥,输入秘钥名称,点击确 ...

  7. mybatis由浅入深day01_4入门程序_4.6根据用户id(主键)查询用户信息

    4 入门程序 4.1 需求 根据用户id(主键)查询用户信息 根据用户名称模糊查询用户信息 添加用户 删除 用户 更新用户 4.2 环境 java环境:jdk1.7.0_72 eclipse:indi ...

  8. swift - UITextView的用法

    1,多行文本控件的创建 textView.frame = CGRect(x:50,y:180,width:self.view.bounds.size.width - 100,height:50) te ...

  9. Python 插件安装

    0.下载Python包文件后,解压缩: 1.cd 到 插件解压缩目录,里面有setup.py的文件: 2.定位到当前目录: 3.执行:python setup.py install; 4.结束安装. ...

  10. 盒子模型 W3C中和IE中盒子的总宽度分别是什么

    W3C盒模型 总宽度 = margin-left + border-left + padding-left + width + padding-right + border-right + margi ...