oracle sequence order_oracle session

oracle sequence order_oracle session在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。  1、Create Sequence  你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,  CREATE SEQUEN

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

Jetbrains全系列IDE稳定放心使用
 在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;  

一旦定义了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 emp VALUES   
(empseq.nextval, ‘LEWIS’, ‘CLERK’,7902, SYSDATE, 1200, NULL, 20);  

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; 

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

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

(0)
上一篇 2022年10月10日 下午5:36
下一篇 2022年10月10日 下午5:36


相关推荐

  • PREROUTING 和 POSTROUTING, SNAT 和 DNAT图文解析(非常清淅)

    PREROUTING 和 POSTROUTING, SNAT 和 DNAT图文解析(非常清淅)NAT 网络地址转换 技术在平时是很多见的 如家庭中在使用路由器共享上网时 一般用的就是 NAT 技术 它可以实现众多内网 IP 共享一个公网 IP 上网 NAT 的原理简单的说就是当内网主机访问外网时 当内网主机的数据包要通过路由器时 路由器将数据包中的源内网 IP 地址改为路由器上的公网 IP 地址 同时记录下该数据包的消息 当外网服务器响应这次由内而外发出的请求或数据交换时 当外

    2026年3月19日
    2
  • 定时任务cron表达式工具

    定时任务cron表达式工具推荐一个定时任务 cron 表达式工具 特别好用定时任务 cron 表达式工具

    2026年3月16日
    2
  • sdram控制器设计

    sdram控制器设计SDRAM控制器

    2022年7月1日
    22
  • 银行家算法c语言代码运行界面,银行家算法C语言模拟程序[通俗易懂]

    银行家算法c语言代码运行界面,银行家算法C语言模拟程序[通俗易懂]银行家算法C语言模拟程序这个最简单的模拟程序,为了完成操作系统作业而做的。大家放心,绝对可以运行,呵呵!有什么不完善的地方请提出!(在计数器的运用上比较乱,希望大家看的明白)作者:luo卢丹)源程序:#include#include#includeintAvailable[10];//可使用资源向量intMax[10][10];//最大需求矩阵i…

    2022年7月22日
    14
  • Manus vs ChatGPT,比拼任务执行能力,谁更胜一筹?

    Manus vs ChatGPT,比拼任务执行能力,谁更胜一筹?

    2026年3月15日
    2
  • pycharm断点运行_python断点调试技巧

    pycharm断点运行_python断点调试技巧pycharm打断点debug入门  断点调试是在开发过程中常用的功能,能清楚看到代码运行的过程,有利于代码问题跟踪。对我这个小白开发来说,还有一个作用是快速熟悉代码,拿到别人写的代码,有时看不太懂或看的很吃力,光这样看很无感,但是通过断点调试,可以很清楚的看到代码是怎么走的,每一步的参数的值等,驱动代码熟悉。  pycharm打断点很简单,在代码行号后空白槽点击一下,出现红球,就可以…

    2022年8月28日
    4

发表回复

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

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