序列的作用

  • 许多的数据库之中都会为用户提供一种自动增长列的操作,例如:在微软的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. csv导入mysql提示错误[Error Code] 1290 - The MySQL server is running with the --secure-file-priv option

    解决方法: 1.进入mysql查看secure_file_prive的值 mysql>SHOW VARIABLES LIKE "secure_file_priv"; secu ...

  2. 编译 & 执行 C++ 程序

    编译 & 执行 C++ 程序接下来让我们看看如何把源代码保存在一个文件中,以及如何编译并运行它.下面是简单的步骤: 打开一个文本编辑器,添加上述代码.保存文件为 hello.cpp.打开命令提 ...

  3. 刚刚完成了在vs2013中通过 ef连接mysql数据库的工作。感觉没有想象中的简单。试了n次终于成功。故记录成功的方法,希望可以帮到大家

    分两种情况,如果你是用entity framework 5.0的时候 mysql-connector-net的版本不是很重要. MySQL For VisualStudio的版本也不重要 (这个不装就 ...

  4. xshell-常用指令汇总 linux 常用指令

    suse linux 常用命令  (1)命令ls——列出文件  ls -la 给出当前目录下所有文件的一个长列表,包括以句点开头的“隐藏”文件  ls a* 列出当前目录下以字母a开头的所有文件  l ...

  5. OpenCV学习:改变图像的对比度和亮度

    本实例演示简单地改变图像的对比度和亮度,使用了如下线性变换来实现像素值的遍历操作: The parameters α > 0 and β often called the gain and bi ...

  6. VS2008远程调试操作方法

    前言 最近遇到一个问题:组态王在本地调试机上运行正常,但在远程测试机上运行却出现了崩溃.本机上装有Visual Studio 2008,测试机上则没有.于是,在网上找资料,想利用远程调试方法,在本机上 ...

  7. js 去掉空格.回车.换行

    Jquery:$("#accuracy").val($("#accuracy").val().replace(/\ +/g,""));//去 ...

  8. linux中,如何设置每隔2个小时就执行一次某个脚本?

    需求描述: 今天同事问了一个linux上crontab定时任务的问题,说,如何调整一个定时任务每2个小时 执行一次,在此记录下. 操作过程: 1.通过以下的方式设置,每2个小时执行一次脚本 */ * ...

  9. windows平台的游戏运行库

    每一个都在PC上玩过游戏的人,都知道要安装一些必备的游戏运行库,游戏才能运行,这里指的PC是特指Windows操作系统平台.一般来说最常见的运行库是DirectX.Microsoft Visual C ...

  10. docker学习-docker容器