2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 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 节 中有更详细的讨论。

提交更正

如果您在文档中发现任何不正确之处,与您在使用特定功能时的经验不符,或者需要进一步澄清,请使用 此表单 报告文档问题。