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

news2024/9/23 21:28:05

目录

一、前言

二、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是一个强大的数据管理工具,它可以帮助您有效地管理和使用数据。

——结束

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1285464.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端开发者眼中的Node.js未来发展趋势

前言 随着互联网的高速发展,前端开发领域的技术也在不断演进,各种各样的前端技术日新月异,前端框架也是层出不穷。在这个变化的过程中,Node.js作为一种强大的服务器端运行环境,已经成为前端开发者的重要技术之一&#…

netty源码:(4)ServerBootstrap

ServerBootstrap的group方法用来给成员变量赋值,如下图 AbstractBootstrap为ServerBootstrap的父类。 ServerBootstrap的channel方法用来设置channelFactory成员变量(在父类AbstractBootstrap里) ServerBootstrap的childHandler方法用来给本类的成员…

MySQL笔记-第05章_排序与分页

视频链接:【MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板】 文章目录 第05章_排序与分页1. 排序数据1.1 排序规则1.2 单列排序1.3 多列排序 2. 分页2.1 背景2.2 实现规则2.3 拓展 第05章_排序与分页 讲师&#…

HNU-电路与电子学-2021期末A卷(不含解析)

【写在前面】 电路与电子学好像是从2020级开设的课程,故实际上目前只有2020与2021两个年级考过期末考试。 本份卷子的参考性很高,这是2020级的期末考卷。题目都是很典型的,每一道题都值得仔细研究透。 特别注意:看得懂答案跟写得…

【C++】map和set的使用及注意事项

map和set的使用及注意事项 1.关联式容器2. 键值对3.set3.1接口介绍3.1.1构造3.1.2迭代器3.1.3容量3.1.4修改 3.2set使用及注意事项 4.multiset5.map6.multimap349. 两个数组的交集 1.关联式容器 在初阶阶段,我们已经接触过STL中的部分容器,比如&#xf…

【EI会议征稿中】2024年第四届数字信号与计算机通信国际学术会议(DSCC 2024)

2024年第四届数字信号与计算机通信国际学术会议(DSCC 2024) 2024 4th International Conference on Digital Signal and Computer Communications 第四届数字信号与计算机通信国际会议(DSCC 2024)将于2024年4月12日至14日在中国-香港举行。DSCC 2024旨…

什么是Amazon Lambda(无服务器计算服务)

Lambda 在高可用性计算基础设施上运行代码,用于执行计算资源的所有管理工作。这包括服务器和操作系统维护、容量调配和弹性伸缩、代码和安全补丁部署以及代码监控和日志记录。您只需要提供代码。 最近亚马逊云服务提供了超多免费的云服务,快来领取免费套…

Shein、Temu拓荒背后,中国快递业“卷”向海外

【潮汐商业评论/原创】 在中国互联网行业,软银创始人孙正义有一个耳熟能详的“时光机理论”,意思是充分利用不同国家和行业之间发展的不平衡,在发达市场获取经验,然后利用这些经验去开发落后的市场。从发达市场到落后市场的穿越&…

人体姿态估计算法

人体姿态估计算法 1 什么是人体姿态估计2 基于经典传统和基于深度学习的方法2.1 基于经典传统的人体姿态估计算法2.2 基于深度学习的人体姿态估计算法OpenPoseAlphaPose (RMPE) 3 算法应用4 Paper 人体姿态估计在现实中的应用场景很丰富,如下 动作捕捉:三…

小程序开发

1.准备工作 1.注册公众平台账号(免费)2.下载小程序开发工具(免费) 2.开发步骤 1.第一个小程序 1.小程序的AppID相当于小程序平台的一个身份证,这里使用的是测试号(注意区别于服务号或订阅号的AppID&#xf…

浪潮信息KeyarchOS——保卫数字未来的安全防御利器

浪潮信息KeyarchOS——保卫数字未来的安全防御利器 前言 众所周知,目前流行的操作系统有10余种,每一款操作系统都有自己的特点。作为使用者,我们该如何选择操作系统。如果你偏重操作系统的安全可信和稳定高效,我推荐你使用浪潮信…

服务器巡检表

《服务器巡检表》检查项: 1、系统资源 2、K8S集群 3、Nginx 4、JAVA应用 5、RabbitMQ 6、Redis 7、PostgreSQL 8、Elasticsearch 9、ELK日志系统 获取软件开发全套资料进主页。

连夜整理的6个开源项目,都很实用

偶然找到的这个宝藏网站,站内集齐了大量的开源项目。 推荐实用的项目 1、vueNextAdmin 基于 vue3.x CompositionAPI setup 语法糖 typescript vite element plus vue-router-next pinia 技术,适配手机、平板、pc 的后台开源免费模板,…

分享67个节日PPT,总有一款适合您

分享67个节日PPT,总有一款适合您 67个节日PPT下载链接:https://pan.baidu.com/s/1oU-UUCV_69e8Gp5Y6zrzVA?pwd6666 提取码:6666 Python采集代码下载链接:采集代码.zip - 蓝奏云 学习知识费力气,收集整理更不易…

k8s部署单机模式的minio

k8s部署单机模式的minio 一、说明二、yaml内容三、步骤3.1 创建资源3.2 查看启动日志3.2 查看svc并访问控制台 一、说明 项目使用minio,准备在k8s环境部署一套minio试用。 1.关于minio的原理和概念参考: https://mp.weixin.qq.com/s?__bizMzI3MDM5NjgwNg&mid…

vagrant up卡死问题

环境 OS:Windows 10Vagrant:Vagrant 2.2.14VirtualBox:6.1.18 r142142box:CentOS-7-x86_64-Vagrant-2004_01.VirtualBox.box 详细信息 解决办法 修改文件Vagrantfile,增加如下配置,测试可以正常启动 conf…

为什么 PostgreSQL 能代替 MongoDB?

在进行技术选型时,需要考虑众多因素,如功能、性能、可靠性、成本效益、社区支持和团队技术能力等,然而,影响最终决定的关键因素的往往是团队 Leader 的技术品味,这也能解释为什么阿里偏爱 Java,而字节跳动更…

判断一个链表是否为回文结构

📑打牌 : da pai ge的个人主页 🌤️个人专栏 : da pai ge的博客专栏 ☁️宝剑锋从磨砺出,梅花香自苦寒来 🌤️题目结构 给定一个…

Vue 理解MVVM设计模式

vue作者在最初设计vue的时候参考了mvvm这个模型。没有完全遵循mvvm,是在一定程度上遵循了这个模型。根据这个模型设计了vue里面的模型。 MVVM模型 1.M:模型(Model):对应vue代码当中data中的数据,模型就是vue里面的数据 2.V&#x…

AT COMMAND(转载)

AT(Attention)指令是由 Dennis Hayes 发明的,所以也称为 Hayes command set。AT 指令最初是用来指导 modem 工作的,后面随着技术的发展,低速 modem 已经退出了市场,但 AT 指令却不断发展,并且在…