可以为列分配默认值。当创建新行且未为某些列指定值时,这些列将填充其各自的默认值。数据操作命令也可以显式请求将列设置为其默认值,而无需知道该值是什么。(有关数据操作命令的详细信息,请参阅第 6 章。)
如果没有显式声明默认值,则默认值为空值。这通常是有道理的,因为空值可以被认为是表示未知数据。
在表定义中,默认值列在列数据类型之后。例如
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 节中进一步讨论。
如果您在文档中看到任何不正确、与您的特定功能体验不符或需要进一步澄清的内容,请使用此表格报告文档问题。