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

目录

++一、前言++

++二、GaussDB数据库中的序列++

++[1、语法(CREATE SEQUENCE)](#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)

sql 复制代码
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、示例一:创建普通序列

sql 复制代码
--创建一个名为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、示例二:创建与表关联的序列

sql 复制代码
--创建序列,并通过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是一个强大的数据管理工具,它可以帮助您有效地管理和使用数据。

------结束

相关推荐
Wang's Blog44 分钟前
Redis: 集群环境搭建,集群状态检查,分析主从日志,查看集群信息
数据库·redis
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO1 小时前
MySQL事务
数据库·mysql
cyt涛3 小时前
MyBatis 学习总结
数据库·sql·学习·mysql·mybatis·jdbc·lombok
Rookie也要加油3 小时前
01_SQLite
数据库·sqlite
liuxin334455663 小时前
教育技术革新:SpringBoot在线教育系统开发
数据库·spring boot·后端
看山还是山,看水还是。4 小时前
MySQL 管理
数据库·笔记·mysql·adb
fishmemory7sec4 小时前
Koa2项目实战2(路由管理、项目结构优化)
数据库·mongodb·koa
momo小菜pa4 小时前
【MySQL 09】表的内外连接
数据库·mysql
Jasonakeke5 小时前
【重学 MySQL】四十九、阿里 MySQL 命名规范及 MySQL8 DDL 的原子化
数据库·mysql
程序猿小D5 小时前
第二百六十九节 JPA教程 - JPA查询OrderBy两个属性示例
java·开发语言·数据库·windows·jpa