2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4

5.2. 默认值 #

可以为列分配默认值。当创建新行并且未为某些列指定值时,这些列将填充其各自的默认值。数据操作命令还可以显式请求将列设置为其默认值,而无需知道该值是什么。(有关数据操作命令的详细信息,请参见第6章。)

如果没有显式声明默认值,则默认值为 null 值。这通常是有意义的,因为 null 值可以被认为表示未知数据。

在表定义中,默认值列在列数据类型之后。例如

CREATE TABLE products (
    product_no integer,
    name text,
    price numeric DEFAULT 9.99
);

默认值可以是表达式,该表达式将在插入默认值时进行计算(不是在创建表时)。一个常见的示例是使timestamp列的默认值为CURRENT_TIMESTAMP,以便将其设置为行插入的时间。另一个常见示例是为每一行生成一个序列号。在PostgreSQL中,这通常通过以下方式完成

CREATE TABLE products (
    product_no integer DEFAULT nextval('products_product_no_seq'),
    ...
);

其中nextval()函数从序列对象(参见第9.17节)中提供连续的值。这种安排非常常见,因此有一个特殊的简写形式

CREATE TABLE products (
    product_no SERIAL,
    ...
);

SERIAL简写将在第8.1.4节中进一步讨论。

提交更正

如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步说明的内容,请使用此表单报告文档问题。