Oracle序列(基础操作)

序列概念

序列是用于生成唯一连续序号对象

序列可以是升序的,也可以是降序的。

使用CREATE SEQUENCE语句创建序列

sql 复制代码
start with 1   指定第一个序号从1开始
increment by 1 指定序号之间的间隔为1
increment by -1 降序1000 999 998这样
maxvalue 2000  表示序列的最大值为2000
minvalue 1     序列的最小值为1
NOCYCLE        达到2000以后就报错比如2001
CYCLE          达到2000以后跳到1
CACHE 10       指定内存中预先分配的序号数

create sequence stu_seq
	   start with 1
	   increment by 1
	   maxvalue 2000
	   minvalue 1
	   nocycle
	   cache 10;

查看用户包含角色权限

dba 全局(所有用户) usr 用户本身

sql 复制代码
create user t1 identified by t1;

grant resource,connect to t1;

conn t1/t1

SQL> select * from user_role_privs;
CONNECT
RESOURCE

SQL> select * from role_sys_privs;
ROLE                           PRIVILEGE                                ADMIN_OPTION
------------------------------ ---------------------------------------- ------------
RESOURCE                       CREATE SEQUENCE                          NO
RESOURCE                       CREATE TRIGGER                           NO
RESOURCE                       CREATE CLUSTER                           NO
RESOURCE                       CREATE PROCEDURE                         NO
RESOURCE                       CREATE TYPE                              NO
CONNECT                        CREATE SESSION                           NO
RESOURCE                       CREATE OPERATOR                          NO
RESOURCE                       CREATE TABLE                             NO
RESOURCE                       CREATE INDEXTYPE                         NO
9 rows selected

resource 角色包含 CREATE SEQUENCE

创建序列

sql 复制代码
conn t1/t1
create sequence stu_seq
	   start with 1
	   increment by 1
	   maxvalue 2000
	   minvalue 1
	   nocycle
	   cache 10;
	   
#查看用户拥有的序列
select * from user_sequences;

cache含义

sql 复制代码
1 2 3 4 5 ... 2000
第一种:1 生成发给用户 2 生成发给用户
第二种:1 生成发给用户 但是 2 3 4 5 6 生成以后全部放到内存中
第二种的好处就是不用再次计算,直接从内存发给用户。

默认的cache是多少?

sql 复制代码
create sequence seq2 start with 1 increment by 1;

默认的cache是20

访问序列

通过序列伪列来访问序列的值
NEXTVAL返回序列下一个值
CURRVAL 返回序列当前值
第一次使用序列中的值的时候,要使用NEXTVAL

sql 复制代码
conn t1/t1

select stu_seq.nextval from dual;

select stu_seq.currval from dual;
#接着访问该序列的话,值就是一直递增的!
select stu_seq.nextval from dual;
sql 复制代码
create table student(sno number(4),sname varchar(2));
insert into student values(stu_seq.nextval,'A');
insert into student values(stu_seq.nextval,'B');
insert into student values(stu_seq.nextval,'C');

高级用法

sql 复制代码
||       是字符串连接
tochar() 是把数字转字符
insert into student values('2025_'||tochar(stu_seq.nextval),'C');

更改和删除序列

sql 复制代码
#不能更改序列的START WITH参数
alter sequence stu_seq maxvalue 5000 cycle;

#删除序列
drop sequence stu_seq;
相关推荐
学Linux的语莫1 分钟前
mysql主从同步(复制)搭建
数据库·mysql
SelectDB7 分钟前
慢 SQL 诊断准确率 99.99%,天翼云基于 Apache Doris MCP 的 AI 智能运维实践
数据库·人工智能·apache
JIngJaneIL8 分钟前
基于java+ vue交友系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·交友
egoist202315 分钟前
【Linux仓库】超越命令行用户:手写C语言Shell解释器,解密Bash背后的进程创建(附源码)
linux·c语言·bash·xshell·环境变量·命令行参数·内建命令
Lenyiin15 分钟前
《 Linux 修炼全景指南: 八 》别再碎片化学习!掌控 Linux 开发工具链:gcc、g++、GDB、Bash、Python 与工程化实践
linux·python·bash·gdb·gcc·g++·lenyiin
莲华君18 分钟前
Bash Shell:从入门到精通
linux
风雨飘逸19 分钟前
【shell&bash进阶系列】(二十一)向脚本传递参数(shift和getopts)
linux·运维·服务器·经验分享·bash
zly350024 分钟前
删除文件(rm 命令 删除目录)
linux·运维·服务器
fbllfbll25 分钟前
Alpine下部署Nginx+MAZANOKE在线批量压缩图片
服务器·nginx·pve·alpine·lxc容器·在线压缩图片·mazanoke
被AI抢饭碗的人27 分钟前
linux:线程池
linux·开发语言