加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

UPDATE FROM子句中的postgresql – GROUP BY

发布时间:2020-12-13 16:35:45 所属栏目:百科 来源:网络整理
导读:我真的需要做这样的事情: 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,
我真的需要做这样的事情:
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子句,如下所示:
UPDATE 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语句中(它必须是聚合函数而不是简单的列引用),因此它将不起作用。

否则,你到底在做什么呢?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读