我有三个表(№1,№2,№3),我想做一个总结。在表№1中,记录数据,然后将其与表№2进行比较,如果其中至少有一列存在差异,则将其写入表№3。如果没有,则什么也没有。检查后,表№1变成№2,表№2被删除或覆盖。
第一个问题是,如何做到这一点?
第二个问题,我应该写什么到表中,以便数据被覆盖而不是以新的方式添加?*
我使用postgresql 14,如果不清楚,我可以绘制一个图表
发布于 2022-08-01 14:22:01
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或者插入..。回来了。作为行动的练习。
https://stackoverflow.com/questions/73194628
复制相似问题