簡體   English   中英

upsert 到返回最后一條記錄的 id 的表 upsert

[英]upsert to table returning the id of last record upserted

我有一個非常簡單的 upsert,我正在努力工作,但到目前為止沒有成功。

考慮下表:

CREATE TABLE bla(id TEXT PRIMARY KEY, data INT);

和插入:

INSERT INTO bla(id, data) VALUES('12wed', 23) RETURNING (id);

到目前為止一切都很好。

我試圖實現的邏輯如下:

if no record with id=id: 
    insert and return id, 
else:
    do nothing

我試過了

INSERT INTO bla(id, data) VALUES('12wed', 23) 
RETURNING (id) 
ON CONFLICT(id) DO NOTHING;

但我收到以下錯誤:

ERROR:  syntax error at or near "ON"
LINE 3: ON CONFLICT(id) DO NOTHING;

你在表達上犯了一個錯誤。 正確的版本:

INSERT INTO bla(id, data) VALUES('12wed', 23) 
ON CONFLICT(id) DO NOTHING
RETURNING (id);

這正是您想要的:

hh=# INSERT INTO bla(id, data) VALUES('12wed', 23) ON CONFLICT(id) DO NOTHING RETURNING (id);
 id 
----
(0 rows)

INSERT 0 0
hh=# INSERT INTO bla(id, data) VALUES('12wed_new', 23) ON CONFLICT(id) DO NOTHING RETURNING (id);
   id   
--------
 12wed_new
(1 row)

INSERT 0 1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM