openGauss 中的 sequence 跟 Oracle 的 sequence 有什么区别?

openGauss 中也提供了 sequence 序列功能,使用 Oracle 的用户应该都非常喜欢使用这个功能。所以如果从 Oracle 迁移到 openGauss,那么这项功能可以完全替代了。

接下来我们简单测试一下:

enmotech=> drop table test;

DROP TABLE

enmotech=> create table test(id serial,name varchar(20));

NOTICE: CREATE TABLE will create implicit sequence "test_id_seq" for serial column "test.id"

CREATE TABLE

enmotech=> \d+ test

Table "public.test"

Column | Type | Modifiers | Storage | Stats target | Description

--------+-----------------------+---------------------------------------------------+----------+--------------+-------------

id | integer | not null default nextval('test_id_seq'::regclass) | plain | |

name | character varying(20) | | extended | |

Has OIDs: no

Options: orientation=row, compression=no

enmotech=> insert into test values (nextval('test_id_seq'),'enmotech');

INSERT 0 1

enmotech=> insert into test values (nextval('test_id_seq'),'killdb.com');

INSERT 0 1

enmotech=> insert into test values (nextval('test_id_seq'),'www.killdb.com');

INSERT 0 1

enmotech=> select * from test;

id | name

----+----------------

2 | enmotech

3 | killdb.com

4 | www.killdb.com

(3 rows)

同时我们也可以单独创建序列,然后指定给某个表所使用,如下是 create sequence 的语法:

CREATE SEQUENCE name [ INCREMENT [ BY ] increment ]

[ MINVALUE minvalue | NO MINVALUE | NOMINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE | NOMAXVALUE]

[ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE | NOCYCLE ]

[ OWNED BY { table_name.column_name | NONE } ];

接下来我们单独创建使用 sequence 试试:

enmotech=> create sequence kill_seq cache 1000;

CREATE SEQUENCE

enmotech=>

enmotech=> drop table test;

DROP TABLE

enmotech=> create table test(id int not null default nextval('kill_seq'),name varchar(200));

CREATE TABLE

enmotech=>

enmotech=> \d+ test

Table "public.test"

Column | Type | Modifiers | Storage | Stats target | Description

--------+------------------------+------------------------------------------------+----------+--------------+-------------

id | integer | not null default nextval('kill_seq'::regclass) | plain | |

name | character varying(200) | | extended | |

Has OIDs: no

Options: orientation=row, compression=no

enmotech=> alter sequence kill_seq increment by 10 NOCYCLE;

ERROR: ALTER SEQUENCE is not yet supported.

enmotech=>

enmotech=> \d+ kill_seq

Sequence "public.kill_seq"

Column | Type | Value | Storage

---------------+---------+---------------------+---------

sequence_name | name | kill_seq | plain

last_value | bigint | 1000 | plain

start_value | bigint | 1 | plain

increment_by | bigint | 1 | plain

max_value | bigint | 9223372036854775807 | plain

min_value | bigint | 1 | plain

cache_value | bigint | 1000 | plain

log_cnt | bigint | 32 | plain

is_cycled | boolean | f | plain

is_called | boolean | t | plain

uuid | bigint | 0 | plain

enmotech=> alter sequence kill_seq nomaxvalue;

ALTER SEQUENCE ^

enmotech=> alter sequence kill_seq cache 10000;

ERROR: ALTER SEQUENCE is not yet supported.

enmotech=> alter sequence kill_seq start 888;

ERROR: ALTER SEQUENCE is not yet supported.

enmotech=> \d+ kill_seq

Sequence "public.kill_seq"

Column | Type | Value | Storage

---------------+---------+---------------------+---------

sequence_name | name | kill_seq | plain

last_value | bigint | 1000 | plain

start_value | bigint | 1 | plain

increment_by | bigint | 1 | plain

max_value | bigint | 9223372036854775807 | plain

min_value | bigint | 1 | plain

cache_value | bigint | 1000 | plain

log_cnt | bigint | 0 | plain

is_cycled | boolean | f | plain

is_called | boolean | t | plain

uuid | bigint | 0 | plain

尽管 sequence 的属性跟 Oracle 类似,但是我们可以看到,目前 openGauss 暂时还不支持 alter sequence 的方式去修改序列增长步长或其他属性。只能修改 owner 属主。 查了一下官方文档,发现 alter sequence 只支持如下的语法操作:

ALTER SEQUENCE [ IF EXISTS ] name

[MAXVALUE maxvalue | NO MAXVALUE | NOMAXVALUE]

[ OWNED BY { table_name.column_name | NONE } ] ;

需要注意的是,openGauss 中的 sequence 跟 Oracle 中的序列不一样的是,Oracle 由于集群的原因,序列还存在一个 order 或 noorder 选项。但在 openGauss 中 sequence 是不存在这个属性的。

openGauss中的sequence跟Oracle的sequence有什么区别?的更多相关文章

  1. Hibernate用Oracle的sequence生成自增Id

    <?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBL ...

  2. Oracle序列(Sequence)创建、使用、修改、删除

    Oracle对象课程:序列(Sequence)创建.使用.修改.删除,序列(Sequence)是用来生成连续的整数数据的对象.序列常常用来作为主键中增长列,序列中的可以升序生成,也可以降序生成.创建序 ...

  3. oracle之sequence详解

    Oracle提供了sequence对象,由系统提供自增长的序列号,每次取的时候它会自动增加,通常用于生成数据库数据记录的自增长主键或序号的地方. sequence的创建需要用户具有create seq ...

  4. Oracle 序列(sequence)

    序列(sequence) 是Oracle提供的用于生成一系列唯一数字的数据库对象.它会自动生成顺序递增或者递减的序列号,以实现自动提供唯一的主键值.序列可以在多用户并发环境中使用,并且可以为所有用户生 ...

  5. Oracle:sequence问题研究

    一直以来,以为sequence是不间断地持续增长的:但今天发现sequence是会跳号,这种情况发生在RAC环境下.在单实例环境下,应该不存在的. sequence截图如下: 数据库表中发生了跳号: ...

  6. 【cl】oracle之Sequence

    sequence:序列 首先要有create sequence或者create any sequence权限: 1.语法如下: create sequence  cltest---序列名 increm ...

  7. oracle创建sequence序列语法

    在oracle中sequence就是序号,每次取的时候它会自动增加.sequence与表没有关系 1.create sequence create sequence SEQ_LOG_ID minval ...

  8. oracle关于sequence的个人理解

    oracle关于sequence的个人理解 1. sequence在多用户使用时的同步问题 个人感觉sequence是以连接(会话)为基础,类似于java中使用mysql的一个connection 网 ...

  9. JDBC读取新插入Oracle数据库Sequence值的5种方法

    Oracle的sequence实现非常灵活,所以也带来一些易用性问题,如何取到新插入记录生成的sequence值与其它数据库有较大差别,本文详国介绍了5种实现读取新插入记录sequence值的方法. ...

  10. Oracle Metric sequence load elapsed time

    Oracle Metric sequence load elapsed time The sequence load elapsed time Oracle metric is the amount ...

随机推荐

  1. curl比较有用的参数

     精选参数: --include // -i curl的输出中包含http头信息--verbose // 比-i更加丰富,>表示请求的信息, <表示curl接收的信息 *表示curl额外提 ...

  2. 自定义ConditionalOnXX注解(二)

    一.前言 在之前的文章<自定义ConditionalOnXX注解>中,介绍了Conditional注解的实现原理和实现自定义Conditional注解的基础方法,但是有些场景我们需要用一个 ...

  3. 在Avalonia项目中使用MediatR和MS.DI库实现事件驱动通信

    大家好,我是沙漠尽头的狼! AvaloniaUI是一个强大的跨平台.NET客户端开发框架,让开发者能够针对Windows.Linux.macOS.Android和iOS等多个平台构建应用程序.在构建复 ...

  4. [QT] 记录一些使用技巧

    目录 概述 打开窗口 弹出消息框 判断文件存在 获取时间 获取子控件 TableWidget设置不可编辑 QT QString判断纯数字 Qt 保存文件选择器 读写ini 概述 最近花了好几天的时间编 ...

  5. [C++逆向] 6 函数的工作原理

    目录 栈帧的形成和关闭 各种调用方式的考察 _stdcall _cdecl _fastcall 使用ebp或者esp寻址 某次调用函数时的栈结构 函数参数 不定长参数 函数的返回值 栈帧的形成和关闭 ...

  6. 牛客周赛34(A~E)

    A 两种情况 两个字符相同只有2 两个字符不相同4 #include <bits/stdc++.h> #define int long long #define rep(i,a,b) fo ...

  7. Zabbix技术分享——snmp异常排查指南

    大家好,我是乐乐.在IT运维中,难免会碰上设备snmp不通的情况,那么,当问题出现的时候,运维工程师该如何快速找到问题所在呢?下面让我们一起来看看吧!   1.IP配置检查 首先检查zabbix监控上 ...

  8. Zabbix6.0使用教程 (五)—zabbix从二进制包安装上篇

    大家好,我是乐乐.上一期我们已经讲过从源代码安装zabbix,本期着重讲从二进制包安装zabbix. 当我们在ZABBIX官方存储库可以看到,Zabbix SIA 提供如下官方RPM和DEB包: ·R ...

  9. 摆脱鼠标系列 - vscode 搜索 自定义快捷键 F1 - 然后F4 搜索 Alt+Shift+回车 跳转到搜索列表 选好后回车进入文件

    摆脱鼠标系列 - vscode 搜索 自定义快捷键 F1 搜索 Alt+Shift+回车 跳转到搜索列表 选好后回车进入文件 F1的设置可能在其他贴子了 最新特大好消息 F4 是搜索完的跳转 等于F1 ...

  10. 13 种在 JavaScript 中删除/过滤数组的方法【转】

    英文 | https://javascript.plainenglish.io/13-methods-to-remove-filter-an-item-in-an-array-and-array-of ...