Postgresql 中文操作指南

5.2. Default Values #

可以为列分配默认值。当创建新行且未为某些列指定值时,这些列将填充各自的默认值。数据操作命令还可以明确请求将列设置为其默认值,而无需知道该值是什么。(有关数据操作命令的详细信息,请参见 Chapter 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() 函数从 sequence object 提供连续值(参见 Section 9.17)。该结构设置十分常见,因此为此配备了专门的简写方式:

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

有关 SERIAL 简写的进一步讨论,请参见 Section 8.1.4