openGauss SQL语法 —ALTER SEQUENCE
创始人
2024-09-26 09:20:33
0

ALTER SEQUENCE

功能描述

修改一个现有的序列的参数。

注意事项

  • 序列的所有者或者被授予了序列ALTER权限的用户或者被授予了ALTER ANY SEQUENCE权限的用户才能执行ALTER SEQUENCE命令,系统管理员默认拥有该权限。但要修改序列的所有者,当前用户必须是该序列的所有者或者系统管理员,且该用户是新所有者角色的成员。
  • 当前版本仅支持修改步长、最大值、最小值、起始值、缓冲值、是否循环、重新开始、归属列和拥有者。若要修改其他参数,可以删除重建,并用Setval函数恢复当前值。
  • ALTER SEQUENCE MAXVALUE不支持在函数和存储过程中使用。
  • 修改序列的最大值后,会清空该序列在所有会话的cache。
  • 如果Sequence被创建时使用了LARGE标识,则ALTER时也需要使用LARGE标识。
  • ALTER SEQUENCE会阻塞nextval、setval、currval和lastval的调用。

语法格式

  • 修改序列属性

    ALTER [ LARGE ] SEQUENCE [ IF EXISTS ] name [ INCREMENT [ BY ] increment ]     [ MINVALUE minvalue | NO MINVALUE | NOMINVALUE ] [MAXVALUE maxvalue | NO MAXVALUE | NOMAXVALUE]     [ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE | NOCYCLE ] [ RESTART [ WITH ] restart ]      [ OWNED BY { table_name.column_name | NONE } ] ; 
  • 修改序列的拥有者

    ALTER SEQUENCE [ IF EXISTS ] name OWNER TO new_owner; 

参数说明

  • name

    将要修改的序列名称。

  • IF EXISTS

    当序列不存在时使用该选项不会出现错误消息,仅有一个通知。

  • INCREMENT

    指定序列的步长。

  • MINVALUE minvalue | NO MINVALUE| NOMINVALUE

    指定序列的最小值。如果没有声明minvalue或者声明了NO MINVALUE,则递增序列的缺省值为1,递减序列的缺省值为-263+1(Large序列为-2127+1)。NOMINVALUE等价于NO MINVALUE

  • MAXVALUE maxvalue | NO MAXVALUE| NOMAXVALUE

    指定序列的最大值。如果没有声明maxvalue或者声明了NO MAXVALUE,则递增序列的缺省值为263-1(Large序列为2127-1),递减序列的缺省值为-1。NOMAXVALUE等价于NO MAXVALUE

  • START

    指定序列的起始值。

  • CACHE

    为了快速访问,而在内存中预先存储序列号的个数。如果没有指定,将保持旧的缓冲值。

  • CYCLE

    用于使序列达到maxvalue或者minvalue后可循环并继续下去。

    如果声明了NO CYCLE,则在序列达到其最大值后任何对nextval的调用都会返回一个错误。

    NOCYCLE的作用等价于NO CYCLE。

    若修改序列为CYCLE,则不能保证序列的唯一性。

  • RESTART

    用于更改序列的当前值,指定的当前值将作为下次调用nextval的结果返回。缺省值为序列的起始值。

  • OWNED BY

    将序列和一个表的指定字段进行关联。这样,在删除那个字段或其所在表的时候会自动删除已关联的序列。

    如果序列已经和表有关联后,使用这个选项后新的关联关系会覆盖旧的关联。

    关联的表和序列的所有者必须是同一个用户,并且在同一个模式中。

    使用OWNED BY NONE将删除任何已经存在的关联。

  • new_owner

    序列新所有者的用户名。用户要修改序列的所有者,必须是新角色的直接或者间接成员,并且那个角色必须有序列所在模式上的CREATE权限。

示例

--创建一个名为serial的递增序列,从101开始。 openGauss=# CREATE SEQUENCE serial START 101;  --创建一个表,定义默认值。 openGauss=# CREATE TABLE T1(C1 bigint default nextval('serial'));  --将序列serial的归属列变为T1.C1。 openGauss=# ALTER SEQUENCE serial OWNED BY T1.C1;  --修改序列步长为2 openGauss=# ALTER SEQUENCE serial INCREMENT 2;  --修改序列最小值为90 openGauss=# ALTER SEQUENCE serial MINVALUE 90;  --修改序列最大值为200 openGauss=# ALTER SEQUENCE serial MAXVALUE 200;  --修改序列起始值为90 openGauss=# ALTER SEQUENCE serial START 90;  --修改序列缓冲值为10 openGauss=# ALTER SEQUENCE serial CACHE 10;  --修改序列循环 openGauss=# ALTER SEQUENCE serial CYCLE;  --修改序列从100重新开始 openGauss=# ALTER SEQUENCE serial RESTART 100;  --删除序列和表。 openGauss=# DROP SEQUENCE serial cascade; openGauss=# DROP TABLE T1; 

相关链接

CREATE SEQUENCE,DROP SEQUENCE

相关内容

热门资讯

推出新举措!0759湛江吴川三... 推出新举措!0759湛江吴川三脚鸡辅助(辅助挂)原来确实有挂(发现开挂辅助下载)-哔哩哔哩1、该软件...
值得注意的是!UU Games... 值得注意的是!UU Games辅助器(辅助挂)其实真的是有挂(传授开挂辅助神器)-哔哩哔哩1、实时U...
经核实!蘑菇云辅助使用视频(辅... 经核实!蘑菇云辅助使用视频(辅助挂)一直是有挂的(带你开挂辅助安装)-哔哩哔哩1、打开软件启动之后找...
受玩家影响!手机游戏辅助器(辅... 受玩家影响!手机游戏辅助器(辅助挂)一贯真的是有挂(实测开挂辅助插件)-哔哩哔哩1、用户打开应用后不...
事发当天!三哥玩辅助(辅助挂)... 事发当天!三哥玩辅助(辅助挂)果然真的是有挂(正品开挂辅助平台)-哔哩哔哩1、全新机制【三哥玩辅助软...
连日来!皇豪辅助(辅助挂)一直... 连日来!皇豪辅助(辅助挂)一直是有挂的(正版开挂辅助安装)-哔哩哔哩1、皇豪辅助透视辅助简单,皇豪辅...
受玩家影响!小逸碰胡脚本(辅助... 受玩家影响!小逸碰胡脚本(辅助挂)果然是有挂(教会开挂辅助工具)-哔哩哔哩亲,关键说明,小逸碰胡脚本...
据权威媒体报道!拼三张辅助器(... 据权威媒体报道!拼三张辅助器(辅助挂)原来真的是有挂(科技开挂辅助下载)-哔哩哔哩1、该软件可以轻松...
据了解!蜜瓜大厅可以装挂吗(辅... 据了解!蜜瓜大厅可以装挂吗(辅助挂)一贯真的是有挂(详细开挂辅助神器)-哔哩哔哩1、让任何用户在无需...
为切实保障!微乐广西小程序脚本... 为切实保障!微乐广西小程序脚本(辅助挂)一直是有挂(详细开挂辅助插件)-哔哩哔哩为切实保障!微乐广西...