我从MySQL切换到PostgreSQL,我想知道我如何能有一个INT列与自动递增。我在PostgreSQL文档中看到了一个名为SERIAL的数据类型,但我在使用它时遇到了语法错误。


当前回答

是的,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 10

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

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

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

创建除非明确要求否则不能重写的标识列。下面的插入将失败,因为总是生成一个列:

insert into foo (id) 
values (1);

然而,这可以被否决:

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

当使用默认生成的选项时,这本质上与现有的串行实现相同:

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

当手动提供值时,底层序列也需要手动调整—与串行列相同。


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

是的,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。

您可以使用任何其他整数数据类型,例如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;

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

抱歉,要重复一个老问题,但这是谷歌上弹出的第一个Stack Overflow问题/答案。

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

这恰好是:

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

希望这对你有所帮助。