我真的需要做这样的事情:
UPDATE table t1 SET column1=t2.column1 FROM table t2 INNER JOIN table t3 USING (column2) GROUP BY t1.column2;
但是postgres说我有关于GROUP BY子句的语法错误。什么是不同的方式来做到这一点?
UPDATE语句不支持GROUP BY,请参见
the documentation.如果要尝试使用t2中的相应行更新t1,则需要使用WHERE子句,如下所示:
原文链接:https://www.f2er.com/postgresql/192892.htmlUPDATE table t1 SET column1=t2.column1 FROM table t2 JOIN table t3 USING (column2) WHERE t1.column2=t2.column2;
如果您需要在分配到t1之前从t2 / t3分组,则需要使用如下的子查询:
UPDATE table t1 SET column1=sq.column1 FROM ( SELECT t2.column1,column2 FROM table t2 JOIN table t3 USING (column2) GROUP BY column2 ) AS sq WHERE t1.column2=sq.column2;
尽管由于t2.column1不包含在GROUP BY语句中(它必须是聚合函数而不是简单的列引用),因此它将不起作用。
否则,你到底在做什么呢?