oracle创建sequence语法_oracle sequence使用

oracle创建sequence语法_oracle sequence使用先假设有这么一个表:createtableS_Depart(DepartIdINTnotnull,DepartNameNVARCHAR2(40)notnull,DepartOrderINTdefault0,constraintPK_S_DEPARTprimarykey(DepartId));

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

先假设有这么一个表:

create

table
S_Depart (
DepartId

INT

not

null
,
DepartName NVARCHAR2(

40
)
not

null
,
DepartOrder

INT

default

0
,

constraint
PK_S_DEPART
primary

key
(DepartId)
);

在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。
1、Create Sequence
你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,
CREATE SEQUENCE emp_sequence
INCREMENT BY 1 — 每次加几个
START WITH 1 — 从1开始计数
NOMAXVALUE — 不设置最大值
NOCYCLE — 一直累加,不循环
CACHE 10; –设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为———NOCACHE
针对S_Depart创建的sequence如下:

create
sequence S_S_DEPART
minvalue

1

maxvalue

999999999999999999999999999

start

with
1

increment

by

1

nocache;

一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL
CURRVAL=返回 sequence的当前值
NEXTVAL=增加sequence的值,然后返回 sequence 值
比如:
emp_sequence.CURRVAL
emp_sequence.NEXTVAL

可以使用sequence的地方:
– 不包含子查询、snapshot、VIEW的 SELECT 语句
– INSERT语句的子查询中
– NSERT语句的valueS中
– UPDATE 的 SET中

可以看如下例子:

insert into S_Depart(departId,Departname,Departorder)values(S_S_Depart.Nextval,

12345

,
1
);

SELECT empseq.currval FROM DUAL;

但是要注意的是:
– 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次 SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白?

– 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。

2、Alter Sequence
你或者是该sequence的owner,或者有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create .
Alter sequence 的例子
ALTER SEQUENCE emp_sequence
INCREMENT BY 10
MAXvalue 10000
CYCLE — 到10000后从头开始
NOCACHE ;

影响Sequence的初始化参数:
SEQUENCE_CACHE_ENTRIES =设置能同时被cache的sequence数目。

可以很简单的Drop Sequence
DROP SEQUENCE order_seq;

一个简单的例子:
createsequence SEQ_ID
minvalue
1
maxvalue
99999999
start with
1
increment by
1
nocache
order
;

建解发器代码为:

createorreplacetrigger tri_test_id
before inserton S_Depart –S_Depart 是表名
for eachrow
declare

nextid number;
begin
IF
:new.DepartId ISNULLor :new.DepartId=
0THEN —DepartId是列名
select SEQ_ID.nextval —SEQ_ID正是刚才创建的
into nextid
from sys.dual;
:new.DepartId:=nextid;
end if;
end tri_test_id;
OK
,上面的代码就可以实现自动递增的功能了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183876.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月31日 上午10:46
下一篇 2022年8月31日 上午10:46


相关推荐

  • 电路板故障测试仪GR4080软件,电路板故障检测仪

    电路板故障测试仪GR4080软件,电路板故障检测仪电路板故障检测仪也称作在线电路维修测试仪和电路维修测试仪 是一种通用型电路板故障检测设备 缺乏图纸资料和不懂电路原理是电路板维修中的难题 电路板故障检测仪的特点是 逐个测试电路板上的元器件 将不同电路板等效为标准电子元器件的不同组合 可以避开电路原理分析 直接将电路板故障定位到集成 IC 分立元件或电路结点上 中文名电路板故障检测仪外文名 CircuitBoard 功

    2026年3月16日
    2
  • webman_cms发布

    webman_cms发布unicms 有你存在一切安好使用 webman 开发一个 cms 由于时间有限 肯定有很多 bug 举一反三 学习使用吧 记得给我点赞啊 也可以关注我其他作品 PHP 框架 码云仓库 https gitee com lizhiliwo webman cms 查看手册使用注意 public 权限 伪静态 需要服务器开启 fileinfo 功能等 gitclonehttp gitee com lizhiliwo webman cms gitcdwebman cmscomp

    2026年3月17日
    2
  • springmvc整合swagger 与 常用注解说明

    springmvc整合swagger 与 常用注解说明

    2021年9月26日
    113
  • 关于python3.7安装matplotlib始终无法成功的问题

    关于python3.7安装matplotlib始终无法成功的问题相信很多新手 包括我自己 在安装完 python3 7 后需要安装 matplotlib 进行数据可视化时总是遇到安装不了的问题 以下简述自己安装时出现的问题 1 安装了 pycharm 后无法通过 setting 中直接安装 2 直接下载对应的 whl 包安装 http mirrors aliyun com pypi simple matplotlib 进入 mi

    2026年3月27日
    1
  • 虚拟机的桥接模式和NAT模式[通俗易懂]

    虚拟机的桥接模式和NAT模式[通俗易懂]1.桥接模式桥接模式:直接连接物理网络,也就是连的你交换机的网络和你主机的IP在一个网段上将虚拟机出来的计算机,直接连入当前的网络环境中,并且独占IP.特点:在当前网络中的全部计算机,都可以访问虚拟机.弊端:1.Ip地址可能会发生变化192.150.1.100/192.168.1.1012.如果这时传递文件时需要依靠交换机/路由器2.NAT模式说明:相当于在windows系…

    2022年6月26日
    37
  • 汇编语言转换成C语言软件_archlinux

    汇编语言转换成C语言软件_archlinux从ARMv8-A开始出现了64位的ARM指令集:Aarch64。

    2022年10月16日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号