首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >你能告诉我如何写得更好或正确吗?

你能告诉我如何写得更好或正确吗?
EN

Stack Overflow用户
提问于 2022-08-01 13:40:41
回答 1查看 26关注 0票数 0

我有三个表(№1,№2,№3),我想做一个总结。在表№1中,记录数据,然后将其与表№2进行比较,如果其中至少有一列存在差异,则将其写入表№3。如果没有,则什么也没有。检查后,表№1变成№2,表№2被删除或覆盖。

第一个问题是,如何做到这一点?

第二个问题,我应该写什么到表中,以便数据被覆盖而不是以新的方式添加?*

我使用postgresql 14,如果不清楚,我可以绘制一个图表

EN

回答 1

Stack Overflow用户

发布于 2022-08-01 14:22:01

代码语言:javascript
复制
CREATE TABLE table1 (id bigserial primary key, a text);
CREATE TABLE
CREATE TABLE table2 (id bigserial primary key, b text);
CREATE TABLE
CREATE TABLE table3 (id bigserial primary key, c text);
CREATE TABLE
INSERT INTO table3 (id,c) (SELECT table1.id, a FROM table1 INNER JOIN table2 ON (table1.id) = (table2.id)  WHERE (table1.a) <> (table2.b));
UPDATE table2 SET b = c FROM table3 WHERE table2.id = table3.id;

你也许可以把上面的语句组合成CTE或者插入..。回来了。作为行动的练习。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73194628

复制
相关文章

相似问题

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