Oracle之序列

Oracle数据库中的序列(sequence)是一种自增编号生成器,常用于创建唯一标识。本文详细介绍了序列的创建、查看、使用及删除,包括startwith、incrementby、maxvalue等参数设置,并强调了使用序列时的注意事项,如首次使用必须调用nextval,以及缓存大小与循环值的关系。同时,还展示了如何在插入数据时使用序列。
摘要由CSDN通过智能技术生成

序列 sequence

是oracle中提供的一组能够自动增长的序号,常常用来生成每条数据的唯一标识

///数据库对象之一,独立于表存在

///主要是提供主键值

语法

 

create sequence 序列名 

start with n 给一个初始值n,默认的初始值是1

increment by n ///增长幅度n,默认的还是1,,n为负数是递减

maxvalue n 有最大值n//nomaxvalue 没有上限

//递减的时候有最小值

minvalue n 有最小值n//nominvalue 没有下限

cycle/nocycle // 循环或者不循环

cache n/nocache /缓存n或者没有缓存 默认值20个序号

 

创建序列

create sequence seq_47

start with 1

increment by 2

maxvalue 100

cycle

cache 30

 

查看序列

当前值:currval

 

下一个值:nextval

 

 

select seq_47.currval from dual/第一次序列里没有值,第一次执行执行下一个值

select seq_47.nextval from dual

 

注意:

1.第一次使用序列的时候必须使用下一个值nextval

2.第一次使用nextval的时候返回的是初始值

 

序列的使用

insert into 表名 values(序列名,'列值')使用序列的时候必须使用下一个值

 

序列的删除

drop sequence 序列名

 

注意:

1.cache 不能大于循环值(最大值)

2.增长幅度必须是整数

3.缓存尽量大些

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值