upsert to table 返回最后插入记录的 id
upsert to table returning the id of last record upserted
我有一个非常简单的 upsert,我正在尝试工作但到目前为止没有成功。
考虑 table:
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
我有一个非常简单的 upsert,我正在尝试工作但到目前为止没有成功。
考虑 table:
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