首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在冲突中更新select的精确行?

如何在冲突中更新select的精确行?
EN

Stack Overflow用户
提问于 2020-10-09 10:07:58
回答 1查看 19关注 0票数 0

我只需要在冲突和所有选定行发生冲突时进行更新

代码语言:javascript
复制
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!
EN

Stack Overflow用户

回答已采纳

发布于 2020-10-09 10:14:42

引用EXCLUDED行的方式与引用带有VALUES子句的INSERT时的方式相同:

代码语言:javascript
复制
INSERT INTO t
SELECT * FROM fdw_t
ON CONFLICT (id)
DO UPDATE
SET id = EXCLUDED.id, etc1 = EXCLUDED.etc1, etc2 = EXCLUDED.etc2;
票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64272981

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档