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. 【Azure Redis】Azure Redis添加了内部虚拟网络后,其他区域的主机通过虚拟网络对等互连访问失败

    问题描述 跨区域无法访问Azure Redis服务, Redis 启用了Network并设置在一个VNET中,现在客户端部署在另一个区域数据中心中,两个数据中心区域使用VNET Peer(对等互连)访 ...

  2. 【Azure 云服务】云服务(经典)迁移到云服务(外延支持)的八个问题

    问题一:云服务( 经典)迁移到外延支持云服务是否需要停机? 通过平台的迁移工具(即验证.准备.提交)进行迁移没有停机时间.但是如果需要准备满足迁移条件,如删除对等互联,使用其他vnet资源则需要额外的 ...

  3. 用 NetworkX + Gephi + Nebula Graph 分析<权力的游戏>人物关系(下篇)

    在上一篇[1]中,我们通过 NetworkX 和 Gephi 展示了<权力的游戏>中的人物关系.在本篇中,我们将展示如何通过 NetworkX 访问图数据库 Nebula Graph. N ...

  4. Tomcat 系列

    Tomcat 系列 目录 Tomcat 系列 一. 基本概念 1.1 java jdk 概念 1.2 jsp.servlet是什么 1.3 web服务器.web容器.应用程序服务器 1.4 tomca ...

  5. [MAUI] 混合开发概念

    ​ 混合开发的概念是相对与原生开发来说的:App不直接运行原生程序,而是在原生程序中运行一个Web程序,原生程序中包含Web运行时,用于承载Web页面.暂且将原生应用称之为Web容器,Web容器应该能 ...

  6. 真实开发中-redis在项目中的应用场景

    一.需求描述 从自己当前负责参与开发的一个项目中来看,redis主要的应用场景有如下几个,第一个是保存用户信息,这个需要频繁的获取.比如 在打开某一个页面进行查询时,就先需要获取用户信息,看用户是否具 ...

  7. FastGithub.UI64位中文版V2.1.4绿色版 - 软件推荐

    推荐理由 相对于改hosts,这个更好用 FastGithub.UI64位中文版V2.1.4绿色版 https://www.cr173.com/soft/670733.html

  8. Set-Alias navi ./navi.bat - 设置别名 - powershell入门 (后期改方案了,换npm script)

    需求 开机要启动好几个服务,原先都用vscode启动,觉得可能比较占内存,所以改成命令行 发现直接运行bat,需要输入./batName.bat 一次还行,天天输入就麻烦了 命令 Set-Alias ...

  9. python 音频通道分离的源码实现

    一 前记 作为一个音频工程师,仅仅依靠鼠标点击,没有一些自己的小工具的话,肯定是不合格的了. 最近用到了一个音频通道分离的功能,这里就用python敲击了一下,这里做个备忘吧,给有需求的小伙伴抛砖引玉 ...

  10. Android IjkPlayer解决RTSP延时300ms左右

    简介 在上一篇<ijkplayer编译-RTSP>中介绍了,ijkplayer如何进行编译成so库的,以及如何开启rtsp.那么实际在使用的时候会发现延迟不是一般的大. 现在来介绍一下如何 ...