序列的作用

  • 许多的数据库之中都会为用户提供一种自动增长列的操作,例如:在微软的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. 第二百九十五节,python操作redis缓存-字符串类型

    python操作redis缓存-字符串类型 首先要安装redis-py模块 python连接redis方式,有两种连接方式,一种是直接连接,一张是通过连接池连接 注意:以后我们都用的连接池方式连接,直 ...

  2. if、for、while、do 等语句自占一行

    if.for.while.do 等语句自占一行,执行语句不得紧跟其后.不论 执行语句有多少都要加{}.这样可以防止书写失误. #include <iostream> /* run this ...

  3. 搭建局域网SVN代码服务器

    1.安装Subversion,安装好后,在控制台输入“svn help”,如果成功安装,则会有很多命令打印输出:2.svnadmin create F:\Java_workspace\Reposito ...

  4. CentOS查看本机公网IP命令

    icanhazip.com 使你在任何地方知道你的公网IP地址 icanhazip.com是一个网址,你在浏览器中输入这个网址,你就能得到你的公网IP地址了. 我在Linux下一般使用curl ica ...

  5. jquery中判断选择器,找没找到元素用$().size()==0

    jquery中判断选择器,找没找到元素用$().size()==0

  6. rdesktop连接远程windows

    $ info rdesktop   //看一下帮助信息吧$rdesktop 192.168.1.1 //打开了一个8位色彩的,$rdesktop -a 16 192.168.1.1 //这个是16位色 ...

  7. 码农小汪-Hibernate学习8-hibernate关联关系注解表示@OneToMany mappedBy @ManyToMany @JoinTable

    近期我也是有点郁闷,究竟是程序中处理关联关系.还是直接使用外键处理关联关系呢?这个的说法不一致!程序中处理这样的关联关系的话.自己去维护这样的约束.这样的非常乐观的一种做法!或者是直接在数据库中处理这 ...

  8. shell脚本中特定符合变量的含义

    shell脚本中特定符合变量的含义: $#   传递到脚本的参数个数 $*    以一个单字符串显示所有向脚本传递的参数.与位置变量不同,此选项参数可超过9个 $$    脚本运行的当前进程PID号 ...

  9. c#.net常用函数和方法集

    1.DateTime 数字型 System.DateTime currentTime=new System.DateTime(); 1.1 取当前年月日时分秒 currentTime=System.D ...

  10. app服务端server端数据库设计