标识列是一种特殊列,其值由隐式序列自动生成。它可用于生成键值。
要创建标识列,可在CREATE TABLE中使用GENERATED ... AS IDENTITY子句,例如:
CREATE TABLE people (
id bigint GENERATED ALWAYS AS IDENTITY,
...,
);
或者:
CREATE TABLE people (
id bigint GENERATED BY DEFAULT AS IDENTITY,
...,
);
更多细节见CREATE TABLE。
如果对带有标识列的表执行INSERT命令,并且没有显式为标识列指定值,则会插入由隐式序列生成的值。例如,在上面的定义下,并假设还有其他合适的列,写成
INSERT INTO people (name, address) VALUES ('A', 'foo');
INSERT INTO people (name, address) VALUES ('B', 'bar');
将会为id列生成从 1 开始的值,并得到如下表数据:
id | name | address ----+------+--------- 1 | A | foo 2 | B | bar
也可以在相应位置写DEFAULT,显式请求使用序列生成的值,例如:
INSERT INTO people (id, name, address) VALUES (DEFAULT, 'C', 'baz');
同样,DEFAULT关键字也可以用于UPDATE命令。
因此,在很多方面,标识列的行为都像带有默认值的列。
列定义中的ALWAYS和BY DEFAULT子句决定了在INSERT和UPDATE命令中如何处理用户显式指定的值。在INSERT命令中,如果选择了ALWAYS,只有当INSERT语句指定了OVERRIDING SYSTEM VALUE时,才接受用户指定的值。如果选择了BY DEFAULT,则用户指定的值优先生效。因此,使用BY DEFAULT的行为更接近默认值,即默认值可以被显式值覆盖;而ALWAYS则能更好地防止意外插入显式值。
标识列的数据类型必须是序列支持的数据类型之一。(见CREATE SEQUENCE。)关联序列的属性可以在创建标识列时指定(见CREATE TABLE),也可以之后再修改(见ALTER TABLE)。
标识列会自动标记为NOT NULL。不过,标识列并不保证唯一性。(序列通常返回唯一值,但序列可能被重置,或者如上所述,也可能手工向标识列插入值。)如果需要唯一性,必须通过PRIMARY KEY或UNIQUE约束来保证。
在表继承层次中,子表中的标识列及其属性与父表中的对应列相互独立。子表不会自动从父表继承标识列或其属性。在INSERT或UPDATE期间,只要语句中指定的那个表里该列是标识列,该列就会被当作标识列处理,并应用相应的标识属性。
分区会从分区表继承标识列。它们不能拥有自己的标识列。某个标识列的属性在整个分区层次中的所有分区上都保持一致。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。