GaussDB数据库SQL系列-序列的使用
一、前言 在数据库管理中,序列(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;`
四、小结 GaussDB 中的CREATE SEQUENCE不仅简单易用,而且具有很高的效率。它可以避免手动分配和管理序列号,大大提高了数据管理的效率。同时,由于序列号的唯一性,它也可以确保数据的完整性和一致性。 总的来说,GaussDB中的CREATE SEQUENCE是一个强大的数据管理工具,它可以帮助您有效地管理和使用数据。
——结束

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
抖音APP如何实现用户生命周期提升
更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群 近日,在火山引擎数智平台在北京举办的“超话数据:企业产品优化分享”的活动上,抖音策略产品经理分享了抖音产品提升用户生命周期的难点及解决办法。 他提到,抖音产品优化涉及到性能、交互、内容和业务等多方面因素,其优化难点主要受用户规模与活跃度影响。抖音目前DAU超6亿,在如此庞大的用户基数下,抖音的优化难点可以概括到三点: 用户规模大,基线高,策略不能一刀切。 优化空间在于少数人群,而非大盘。 同一个策略、交互,数亿用户的反馈不同。 产品优化的传统方法是通过对整体指标进行优化,来综合提升大盘的用户体验。但面对抖音庞大的用户基数,在实践中对大盘用户有用的方法,对于部分人群来说效果并不达预期。综合难点可以分析获知,抖音团队进行产品优化可以分为明确优化性能及其业务表现、明确优化人群、明确产品优化空间、明确实验核心指标及原则,四个步骤进行。 明确优化性能及其业务表现 不同的用户在使用抖音时的体验不同,会对产品产生不同的负向反馈。如果没有及时解决问题优化用户体验,就可能会使用户对抖音产品的价值感走低。传统的产品优化方...
- 下一篇
RustRover 中最常见的 Rust 编译器错误(上)| 技术解析
Rust 编译器相当挑剔, 如果它对输入的源代码不满意,可能会发出 400 多种不同的错误(而且每个月都在增加!)。有些错误极其罕见,另一些则每天都困绕着 Rust 开发者。在这个博文系列中,我们将介绍开发者在 RustRover(JetBrains 推出的专属 Rust IDE)中遇到的最常见 Rust 编译器错误消息,并说明如何避免这些错误。首先,我们来看一下“最常见错误”实际上指的是什么。 从 RustRover 的使用数据中识别最常见的错误 任何 RustRover 用户都可以选择向 JetBrains 发送其匿名使用数据。通过分析这些数据,我们可以观察各种用户模式并深入探究如何改进 IDE。当然,我们非常重视您的隐私,因此 IDE 收集的信息非常有限。例如,数据中的任何内容都无法追溯到用户。但匿名数据仍然可以告诉我们 IDE 的一般使用情况,例如最常生成的错误消息类型。 当选择加入的用户通过 IDE 启动 Cargo Build 命令(例如,通过触发需要构建项目的运行配置)并且 Rust 编译器发出错误时,我们就会记录错误代码。这不包括用户编写代码时出现的所有代码问题,仅包括...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- CentOS关闭SELinux安全模块
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- MySQL8.0.19开启GTID主从同步CentOS8