GaussDB数据库SQL系列-序列的使用

目录

一、前言

二、GaussDB数据库中的序列

1、语法(CREATE SEQUENCE)

2、注意事项

三、GaussDB数据库中的示例

1、示例一:创建普通序列

2、示例二:创建与表关联的序列

四、小结

一、前言

在数据库管理中,序列(SEQUENCE)是一种重要的数据库对象,它为生成唯一标识符提供了方便。 序列的值是按照一定规则自增的整数。因为自增所以不重复,因此说Sequence具有唯一标识性。这也是Sequence常被用作主键的原因。GaussDB是华为公司开发的一款关系型数据库管理系统,它提供了CREATE SEQUENCE命令,帮助用户轻松创建和管理数据库序列。本次主要以CREATE SEQUENCE为内容做一简单介绍。

二、GaussDB数据库中的序列

通过序列使某字段成为唯一标识符的方法有两种:

  • 一种是声明字段的类型为序列整型,由数据库在后台自动创建一个对应的Sequence。
  • 另一种是使用CREATE SEQUENCE自定义一个新的Sequence,然后将nextval('sequence_name')函数读取的序列值,指定为某一字段的默认值,这样该字段就可以作为唯一标识符。

1、语法(CREATE SEQUENCE)

CREATE [ LARGE | TEMPORARY | TEMP ] SEQUENCE name 
       [ MINVALUE minvalue | NO MINVALUE | NOMINVALUE ] 
       [ MAXVALUE maxvalue | NO MAXVALUE | NOMAXVALUE] 
       [ START [ WITH ] start ] [ INCREMENT [ BY ] increment ]
       [ CACHE cache ] [ [ NO ] CYCLE | NOCYCLE ] 
       [ OWNED BY { table_name.column_name | NONE } ];

主要参数说明:

  • start指定序列的起始值。缺省值:对于递增序列为minvalue,递减序列为maxvalue。
  • increment指定序列的步长。一个正数将生成一个递增的序列,一个负数将生成一个递减的序列。缺省值为1。
  • MINVALUE minvalue | NO MINVALUE| NOMINVALUE执行序列的最小值。如果没有声明,则递增序列的缺省值为1,递减序列的缺省值为-263-1。
  • MAXVALUE maxvalue | NO MAXVALUE| NOMAXVALUE执行序列的最大值。如果没有声明,则递增序列的缺省值为263-1,递减序列的缺省值为-1。
  • cache为了快速访问,而在内存中预先存储序列号的个数。
  • CYCLE用于使序列达到maxvalue或者minvalue后可循环并继续下去。如果声明了NO CYCLE,则在序列达到其最大值后任何对nextval的调用都会返回一个错误。NOCYCLE等价于NO CYCLE。缺省值为NO CYCLE。若定义序列为CYCLE,则不能保证序列的唯一性。
  • OWNED BY将序列和一个表的指定字段进行关联。这样,在删除那个字段或其所在表的时候会自动删除已关联的序列。关联的表和序列的所有者必须是同一个用户,并且在同一个模式中。需要注意的是,通过指定OWNED BY,仅仅是建立了表的对应列和sequence之间关联关系,并不会在插入数据时在该列上产生自增序列。

2、注意事项

  • Sequence是一个存放等差数列的特殊表。这个表没有实际意义,通常用于为行或者表生成唯一的标识符。
  • 如果给出一个模式名,则该序列就在给定的模式中创建,否则会在当前模式中创建。序列名必须和同一个模式中的其他序列、表、索引、视图或外表的名称不同。
  • Sequence默认最大值为2^63-1,如果使用了Large标识则最大值可以支持到2^127-1。
  • 被授予CREATE ANY SEQUENCE权限的用户,可以在public模式和用户模式下创建序列。
  • 序列的起始值和增量值必须是整数。
  • 序列名称必须唯一。
  • 尽量避免在序列名称中包含特殊字符。
  • 使用NEXTVAL和CURRVAL函数时,必须指定序列名称。
  • 使用ALTER SEQUENCE和DROP SEQUENCE命令时,必须指定序列名称等。

三、GaussDB数据库中的示例

在GaussDB中,CREATE SEQUENCE提供了一种序列生成器,它可以自动为新插入的行生成唯一的序列号。这个序列号可以用于主键、外键或者唯一约束,确保数据的完整性和一致性。那么,如何使用GaussDB CREATE SEQUENCE呢? 参考如下示例:

1、示例一:创建普通序列

--创建一个名为mysequence的序列,起始值为1,增量为1
CREATE SEQUENCE mysequence START WITH 1 INCREMENT BY 1;

--使用NEXTVAL函数用于获取下一个序列值
SELECT NEXTVAL('mysequence');

--CURRVAL函数用于获取当前序列值
SELECT CURRVAL('mysequence');

--删除mysequence序列
DROP SEQUENCE mysequence;

2、示例二:创建与表关联的序列

--创建序列,并通过NEXTVAL('sequence_name')函数指定为某一字段的默认值。
--第一步:创建序列
CREATE SEQUENCE mysequence1 START 100 CACHE 20;

--第二步:创建一个表
CREATE TABLE test_3(
   id int NOT NULL 
  ,c_date date
);

--将序列serial的归属列变为 test_3.id。
ALTER SEQUENCE mysequence1 OWNED BY test_3.id;

--插入数据并查看结果
INSERT INTO test_3(id,c_date) VALUES(NEXTVAL('mysequence1'),current_timestamp);
INSERT INTO test_3(id,c_date) VALUES(NEXTVAL('mysequence1'),current_timestamp);
INSERT INTO test_3(id,c_date) VALUES(NEXTVAL('mysequence1'),current_timestamp);
SELECT * FROM test_3;

--删除序列和表。
DROP SEQUENCE mysequence1 cascade;
DROP TABLE test_3;

更多信息参见官方资料:

CREATE SEQUENCE_云数据库 GaussDB_主备版_3.x版本_SQL参考_SQL语法_华为云

CREATE SEQUENCE_云数据库 GaussDB_分布式_3.x版本_SQL参考_SQL语法_华为云

四、小结

GaussDB 中的CREATE SEQUENCE不仅简单易用,而且具有很高的效率。它可以避免手动分配和管理序列号,大大提高了数据管理的效率。同时,由于序列号的唯一性,它也可以确保数据的完整性和一致性。  总的来说,GaussDB中的CREATE SEQUENCE是一个强大的数据管理工具,它可以帮助您有效地管理和使用数据。

——结束

猜你喜欢

转载自blog.csdn.net/GaussDB/article/details/134798549