我只需要在冲突和所有选定行发生冲突时进行更新
INSERT INTO t SELECT * FROM fdw_t
ON CONFLICT (id) DO UPDATE
SET id=id, etc1=etc1, etc2=etc2
; -- ERROR: column reference "id" is ambiguous
INSERT INTO t SELECT * FROM fdw_t AS w
ON CONFLICT (id) DO UPDATE
SET id=w.id, etc1=w.etc1, etc2=etc2
; -- ERROR: missing FROM-clause entry for table "w"
-- BUT I NEED the ROW of the select, not other!发布于 2020-10-09 10:14:42
引用EXCLUDED行的方式与引用带有VALUES子句的INSERT时的方式相同:
INSERT INTO t
SELECT * FROM fdw_t
ON CONFLICT (id)
DO UPDATE
SET id = EXCLUDED.id, etc1 = EXCLUDED.etc1, etc2 = EXCLUDED.etc2;https://stackoverflow.com/questions/64272981
复制相似问题