列可以被赋予默认值。当创建新行时,如果没有为某些列指定值,这些列就会填入各自的默认值。数据操作命令也可以显式要求把某列设为其默认值,而不必知道默认值究竟是什么。(数据操作命令详见Chapter 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()函数从序列对象(见Section 9.17)中依次取值。这种写法非常常见,因此还有一种专门的简写形式:
CREATE TABLE products (
product_no SERIAL,
...
);
SERIAL简写会在Section 8.1.4进一步讨论。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。