zoukankan      html  css  js  c++  java
  • 序列

    序列介绍

    序列是一个计数器,它并不会与特定的表关联。通过创建Oracle序列和触发器实现表的主键自增。

    序列的用途一般用来填充主键和计数。

    序列使用


    1.创建序列

    ORACLE序列的语法格式为:

    CREATE SEQUENCE 序列名
    [INCREMENT BY n]
    [START WITH n]
    [{MAXVALUE/ MINVALUE n|NOMAXVALUE}]
    [{CYCLE|NOCYCLE}]
    [{CACHE n|NOCACHE}];

    1)INCREMENT BY用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。

    2)START WITH 定义序列的初始值(即产生的第一个值),默认为1。

    3)MAXVALUE 定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增Oracle序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。

    4)MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是负(10的26次方);对于递增序列,最小值是1。

    5)CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值;最小值为1。对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。

    6)CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。 缓存选项会造成数据丢失,当实例异常关闭时。

    CREATE SEQUENCE SEQ_TEST
    INCREMENT BY 1
    START WITH 1
    MINVALUE 1 NOMAXVALUE
    NOCYCLE;

    2.删除序列

    DROP SEQUENCE SEQ_TEST;


    3:序列使用

    CURRVAL: 返回序列的当前值。
    NEXTVAL: 序列递增,返回下一值。

    你不能使用序列的CURRVAL和NEXTVAL,在下面情况下(具体参见官方文档):
    1:在DELETE、SELECT、UPDATE的子查询中
    2:在视图或物化事物的查询中。
    3:SELECT查询中使用了DISTINCT操作符。
    4:SELECT查询中有GROUP BY或ORDER BY

    4:序列查看

    SELECT * FROM USER_SEQUENCES;

    SELECT * FROM ALL_SEQUENCES;

    SELECT * FROM DBA_SEQUENCES;

    5:序列修改

    不能修改序列的初始值,否则会报ORA-02283:

    SQL> ALTER SEQUENCE SEQ_TEST START WITH 2;

    ALTER SEQUENCE SEQ_TEST START WITH 2

    ORA-02283: 无法更改启动序列号


    SQL> ALTER SEQUENCE SEQ_TEST INCREMENT BY 2;

    Sequence altered

  • 相关阅读:
    hdu 4614 线段树 二分
    cf 1066d 思维 二分
    lca 最大生成树 逆向思维 2018 徐州赛区网络预赛j
    rmq学习
    hdu 5692 dfs序 线段树
    dfs序介绍
    poj 3321 dfs序 树状数组 前向星
    cf 1060d 思维贪心
    【PAT甲级】1126 Eulerian Path (25分)
    【PAT甲级】1125 Chain the Ropes (25分)
  • 原文地址:https://www.cnblogs.com/sangmu/p/6793780.html
Copyright © 2011-2022 走看看