UPDATE FROM子句中的GROUP BY

sen*_*nin 24 postgresql group-by

我真的需要这样做:

UPDATE table t1 
SET column1=t2.column1 
FROM table t2 
INNER JOIN table t3 
USING (column2) 
GROUP BY t1.column2;
Run Code Online (Sandbox Code Playgroud)

但postgres说我有关于GROUP BY子句的语法错误.有什么不同的方法呢?

Ano*_*mie 59

UPDATE语句不支持GROUP BY,请参阅文档.如果您尝试使用t2中的相应行更新t1,则需要使用WHERE子句,如下所示:

UPDATE table t1 SET column1=t2.column1
FROM   table t2
JOIN   table t3 USING (column2)
WHERE  t1.column2=t2.column2;
Run Code Online (Sandbox Code Playgroud)

如果需要在分配给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;
Run Code Online (Sandbox Code Playgroud)

尽管由于t2.column1未包含在GROUP BY语句中而无法生效(但它必须是聚合函数而不是简单的列引用).

否则,你究竟想在这做什么?

  • 我也不明白他想做什么,但这个回应对我还是很有帮助的 =) (3认同)