PostgreSQL:条件插入默认值

Posted

技术标签:

【中文标题】PostgreSQL:条件插入默认值【英文标题】:PostgreSQL: Conditional insert default values 【发布时间】:2017-12-19 20:36:39 【问题描述】:

我们如何有条件地将具有默认值的行插入到表中?

例如,我们有一个一列的表。

CREATE TABLE foo (
    id bigserial PRIMARY KEY
);

而且,我们想做如下的事情:

INSERT INTO foo DEFAULT VALUES
WHERE random() >= 0.5;

但是,我们得到:

ERROR:  syntax error at or near "WHERE"

【问题讨论】:

我相信你有一个理由,但这似乎是一件奇怪的事情。出于好奇,您希望通过这样做来完成什么? 【参考方案1】:

条件插入需要查询,从INSERT documentation 可以看出,queryDEFAULT VALUES 位于一个独占组中。

当明确定义应该填充哪些列时,您至少需要指定一个。所以这样的东西也是无效的:

INSERT INTO foo ()
SELECT 1
WHERE random() >= 0.5;

我能想到的实现相同效果的唯一方法是显式定义“默认”值:

INSERT INTO foo (id)
SELECT nextval('foo_id_seq'::regclass)
WHERE random() > 0.8;

或者通过添加另一列

CREATE TABLE foo (
    id bigserial PRIMARY KEY,
    ignored SMALLINT
);

INSERT INTO foo (ignored) 
SELECT 1
WHERE random() >= 0.5;

编辑:

完全错过了你可以做空选择:

INSERT INTO foo
SELECT
WHERE random() >= 0.5;

【讨论】:

【参考方案2】:
INSERT INTO foo
SELECT -- here is empty select, without any columns
WHERE random() >= 0.5;

Demo

PS:PostgreSQL 中有几个“奇怪”相关的东西。例如,select; 甚至更多的create table t(); 都是有效的语句。

【讨论】:

以上是关于PostgreSQL:条件插入默认值的主要内容,如果未能解决你的问题,请参考以下文章

postgres:更新冲突插入行并返回旧值

错误:Postgresql 中的日期/时间字段值超出范围

Postgres 9.2 - 添加条件约束检查

转义 PostgreSQL 字符串值

如何在 Postgres 中为 UUID 主键列设置默认值?

HSQLDB 中的 Postgresql 时间戳和未来默认值