我正在从MySQL切换到PostgreSQL,并想知道如何做自动增量值。 我在PostgreSQL文档中看到了一个数据类型“serial”,但是在使用它时会出现语法错误(在v8.0中)。


#1楼

在问题的上下文中以及@ sereja1c对评论的回复中,创建SERIAL隐式创建序列,因此对于上述示例 -

CREATE TABLE foo (id SERIAL,bar varchar);

CREATE TABLE将隐含创建序列foo_id_seq串行列foo.id 。 因此,除非您需要特定的id数据类型,否则SERIAL [4 Bytes]的易用性很好。


#2楼

如果要在已存在的表中向id添加序列,可以使用:

CREATE SEQUENCE user_id_seq;
ALTER TABLE user ALTER user_id SET DEFAULT NEXTVAL('user_id_seq');

#3楼

您必须注意不要直接插入SERIAL或序列字段,否则当序列达到插入值时,写入将失败:

-- Table: "test"-- DROP TABLE test;CREATE TABLE test
("ID" SERIAL,"Rank" integer NOT NULL,"GermanHeadword" "text" [] NOT NULL,"PartOfSpeech" "text" NOT NULL,"ExampleSentence" "text" NOT NULL,"EnglishGloss" "text"[] NOT NULL,CONSTRAINT "PKey" PRIMARY KEY ("ID", "Rank")
)
WITH (OIDS=FALSE
);
-- ALTER TABLE test OWNER TO postgres;INSERT INTO test("Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")VALUES (1, '{"der", "die", "das", "den", "dem", "des"}', 'art', 'Der Mann küsst die Frau und das Kind schaut zu', '{"the", "of the" }');INSERT INTO test("ID", "Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")VALUES (2, 1, '{"der", "die", "das"}', 'pron', 'Das ist mein Fahrrad', '{"that", "those"}');INSERT INTO test("Rank", "GermanHeadword", "PartOfSpeech", "ExampleSentence", "EnglishGloss")VALUES (1, '{"der", "die", "das"}', 'pron', 'Die Frau, die nebenen wohnt, heißt Renate', '{"that", "who"}');SELECT * from test;

#4楼

虽然看起来序列等同于MySQL auto_increment,但有一些微妙但重要的区别:

1.失败的查询递增序列/序列

串行列在失败的查询中递增。 这会导致查询失败,而不仅仅是行删除。 例如,在PostgreSQL数据库上运行以下查询:

CREATE TABLE table1 (uid serial NOT NULL PRIMARY KEY,col_b integer NOT NULL,CHECK (col_b>=0)
);INSERT INTO table1 (col_b) VALUES(1);
INSERT INTO table1 (col_b) VALUES(-1);
INSERT INTO table1 (col_b) VALUES(2);SELECT * FROM table1;

你应该得到以下输出:

 uid | col_b
-----+-------1 |     13 |     2
(2 rows)

注意uid如何从1变为3而不是1到2。

如果您使用以下方法手动创建自己的序列,则仍会出现这种情况

CREATE SEQUENCE table1_seq;
CREATE TABLE table1 (col_a smallint NOT NULL DEFAULT nextval('table1_seq'),col_b integer NOT NULL,CHECK (col_b>=0)
);
ALTER SEQUENCE table1_seq OWNED BY table1.col_a;

如果您想测试MySQL的不同之处,请在MySQL数据库上运行以下命令:

CREATE TABLE table1 (uid int unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,col_b int unsigned NOT NULL
);INSERT INTO table1 (col_b) VALUES(1);
INSERT INTO table1 (col_b) VALUES(-1);
INSERT INTO table1 (col_b) VALUES(2);

你应该得到以下没有fragementation

+-----+-------+
| uid | col_b |
+-----+-------+
|   1 |     1 |
|   2 |     2 |
+-----+-------+
2 rows in set (0.00 sec)

2.手动设置串行列值可能导致将来的查询失败。

@trev在之前的回答中指出了这一点。

要模拟此操作,请手动将uid设置为4,以便稍后“冲突”。

INSERT INTO table1 (uid, col_b) VALUES(5, 5);

表数据:

 uid | col_b
-----+-------1 |     13 |     25 |     5
(3 rows)

运行另一个插入:

INSERT INTO table1 (col_b) VALUES(6);

表数据:

 uid | col_b
-----+-------1 |     13 |     25 |     54 |     6

现在,如果你运行另一个插入:

INSERT INTO table1 (col_b) VALUES(7);

它将失败,并显示以下错误消息:

错误:重复键值违反唯一约束“table1_pkey”DETAIL:键(uid)=(5)已存在。

相比之下,MySQL将优雅地处理这个,如下所示:

INSERT INTO table1 (uid, col_b) VALUES(4, 4);

现在插入另一行而不设置uid

INSERT INTO table1 (col_b) VALUES(3);

查询没有失败,uid只跳到5:

+-----+-------+
| uid | col_b |
+-----+-------+
|   1 |     1 |
|   2 |     2 |
|   4 |     4 |
|   5 |     3 |
+-----+-------+

测试是在MySQL 5.6.33上进行的,适用于Linux(x86_64)和PostgreSQL 9.4.9


#5楼

从Postgres 10开始,还支持SQL标准定义的标识列:

create table foo
(id integer generated always as identity
);

除非明确要求,否则会创建一个无法覆盖的标识列。 以下插入将失败,并且列定义为generated always

insert into foo (id)
values (1);

但是,这可以推翻:

insert into foo (id) overriding system value
values (1);

使用generated by default的选项时generated by default这与现有的serial实现基本相同:

create table foo
(id integer generated by default as identity
);

手动提供值时,也需要手动调整基础序列 - 与serial列相同。


默认情况下,标识列不是主键(就像serial列一样)。 如果它应该是1,则需要手动定义主键约束。


#6楼

很抱歉,重新提出一个旧问题,但这是Google上出现的第一个Stack Overflow问题/答案。

这篇文章(首先在Google上发布)讨论了如何使用PostgreSQL 10的更新语法: https : //blog.2ndquadrant.com/postgresql-10-identity-columns/

恰好是:

CREATE TABLE test_new (id int GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,
);

希望有帮助:)


#7楼

这种方式肯定会起作用,我希望它有所帮助:

CREATE TABLE fruits(id SERIAL PRIMARY KEY,name VARCHAR NOT NULL
);INSERT INTO fruits(id,name) VALUES(DEFAULT,'apple');orINSERT INTO fruits VALUES(DEFAULT,'apple');

您可以在下一个链接中查看详细信息: http : //www.postgresqltutorial.com/postgresql-serial/


#8楼

自PostgreSQL 10以来

CREATE TABLE test_new (id int GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY,payload text
);

#9楼

您可以使用任何其他整数数据类型 ,例如smallint

示例:

CREATE SEQUENCE user_id_seq;
CREATE TABLE user (user_id smallint NOT NULL DEFAULT nextval('user_id_seq')
);
ALTER SEQUENCE user_id_seq OWNED BY user.user_id;

最好使用您自己的数据类型,而不是用户串行数据类型 。


#10楼

是的,SERIAL是等效功能。

CREATE TABLE foo (
id SERIAL,
bar varchar);INSERT INTO foo (bar) values ('blah');
INSERT INTO foo (bar) values ('blah');SELECT * FROM foo;1,blah
2,blah

SERIAL只是序列周围的创建表时间宏。 您不能将SERIAL更改为现有列。

PostgreSQL自动增量相关推荐

  1. mysql重置增量_摆脱困境:在每种测试方法之前重置自动增量列

    mysql重置增量 当我们为将信息保存到数据库的功能编写集成测试时,我们必须验证是否将正确的信息保存到数据库. 如果我们的应用程序使用Spring Framework,则可以为此目的使用Spring ...

  2. 摆脱困境:在每种测试方法之前重置自动增量列

    当我们为将信息保存到数据库的功能编写集成测试时,我们必须验证是否将正确的信息保存到数据库. 如果我们的应用程序使用Spring Framework,则可以为此目的使用Spring Test DbUni ...

  3. sql数据库自动增量备份_SQL自动增量

    sql数据库自动增量备份 Sometimes we don't have unique identifiers in the table to create a primary key. In thi ...

  4. adf4351_在ADF实体PK属性中使用MySQL自动增量PK列

    adf4351 大家好. 继续进行ADF + MySQL解决方法系列,今天我们将看到需要做些什么才能将MySQL PK自动增量列与ADF实体PK属性一起使用. 如果我们使用的是Oracle数据库,则可 ...

  5. mysql 行自动增量为23,Mysql Innodb:自动增量非主键

    是否可以自动递增非主键? 表"book_comments" book_id medium_int timestamp medium_int user_id medium_int v ...

  6. [导入]在ASP.NET+ORACLE添加数据记录并让ID自动增量

    在ASP.NET+ORACLE添加数据记录并让ID自动增量需要在ORACLE中设序列和触发器即可,切记不是索引,ASP.NET中不管ID,具体如下: 1.建立序列: CREATE SEQUENCE s ...

  7. adf 自动输稿器_在ADF实体PK属性中使用MySQL自动增量PK列

    adf 自动输稿器 大家好. 继续进行ADF + MySQL解决方法系列,今天我们将看到需要做些什么才能将MySQL PK自动增量列与ADF实体PK属性一起使用. 如果使用的是Oracle数据库,则可 ...

  8. 在ADF实体PK属性中使用MySQL自动增量PK列

    大家好. 继续进行ADF + MySQL解决方法系列,今天我们将看到要使用MySQL PK自动增量列和ADF实体PK属性来进行的工作. 如果使用的是Oracle数据库,则可以使用oracle.jbo. ...

  9. Java自动生成增量补丁自动部署_java-Hibernate正在为表生成自动增量交替ID

    我的环境:WAMP中的Hibernate 5,Java 8,Phpmyadmin 问题:Hibernate在表中创建自动增量ID,但是下一个序列被赋予另一个表. 预期 Table 1 Table 2 ...

最新文章

  1. matlab通信物理层仿真,通信小精灵(物理层仿真工具) 可计算仿真误码率、理论误...
  2. 一致性代码段和非一致性代码段
  3. 元宇宙iwemeta: 重庆打造“数据之都”,拟成立重庆数据交易所
  4. webstorm怎么跑项目_快讯!明年厦门中考体育项目定了!初三家长抽的!其他地市抽到啥?...
  5. spring集成redis(ehcache缓存改成redis)
  6. 1×pbs缓冲液配方_PBS缓冲液的配制
  7. 带有批注的Spring硒测试
  8. AUTOSAR从入门到精通100讲(三十五)-AUTOSAR BswM三部曲-概念实践代码分析
  9. linux php 版本切换,linux更换PHP版本,多个PHP版本切换
  10. python的全局变量 local variable ‘xxx‘ referenced before assignment
  11. 半导体术语-什么CIM
  12. 解决Adobe Illustrator CS5启动后自动关闭的问题
  13. Python 结巴分词(jieba)Tokenize和ChineseAnalyzer的使用及示例代码
  14. 古诗词在线起名 - 一刀工具箱
  15. 2017网易雷火实习生招聘编程题
  16. Mac安装mactex清华源
  17. python中line的意思_关于python代码,line[:-1]的意思
  18. elf文件反编译C语言,图文并茂,讲透C语言静态链接,ELF文件篇
  19. 暴走欧洲之 为信仰买单
  20. curl php 不直接输出,php – 使用cUrl时没有输出

热门文章

  1. 如何将散乱的css代码规范化、格式化
  2. 编译SOCI-3.1.0 开启sqlite3支持
  3. Netbackup code 98错误实战解析
  4. 2003系统安全配置
  5. 十大注意事项 防止系统重装时遭遇病毒
  6. C++的四种cast操作符的区别--类型转换
  7. [其他]Ubuntu安装genymotion后unable to load VirtualBox engine
  8. SQLServer扩展存储过程
  9. 体验Vs2005 beta2 测试工具
  10. CentOS源码安装消息队列ActiveMQ