Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

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,
    ...
);

第 8.1.4 节 中进一步讨论 SERIAL 简写标识符。