On this page
5.2. 默认值
可以为列分配默认值。当创建新行并且未为某些列指定值时,这些列将使用其各自的默认值填充。数据操作命令还可以显式请求将列设置为其默认值,而不必知道该值是什么。 (有关数据处理命令的详细信息,请参见Chapter 6。)
如果未明确声明默认值,则默认值为空值。这通常很有意义,因为可以将空值视为代表未知数据。
在表定义中,默认值在列数据类型之后列出。例如:
CREATE TABLE products (
product_no integer,
name text,
price numeric DEFAULT 9.99
);
默认值可以是一个表达式,只要插入默认值(在创建表时为* not *),就将对其求值。一个常见的示例是timestamp
列的默认值为CURRENT_TIMESTAMP
,以便将其设置为行插入的时间。另一个常见的示例是为每一行生成一个“序列号”。在 PostgreSQL 中,这通常通过以下方式完成:
CREATE TABLE products (
product_no integer DEFAULT nextval('products_product_no_seq'),
...
);
其中nextval()
函数提供来自序列对象的连续值(请参见Section 9.16)。这种安排非常普遍,因此有一个特殊的缩写:
CREATE TABLE products (
product_no SERIAL,
...
);
Section 8.1.4中将进一步讨论SERIAL
的简写。